mirror of
https://github.com/openvswitch/ovs
synced 2025-10-21 14:49:41 +00:00
The current callers of ovsdb_log_open() always want to lock the file if they are accessing it for read/write access. An upcoming commit will add a new caller that does not fit this model (it wants to lock the file across a wider region) and so the caller should be able to choose whether to do locking. This commit adds that ability. Also, get rid of the use of <fcntl.h> flags to choose the open mode, which has always seemed somewhat crude and which this change would make even cruder.
45 lines
1.5 KiB
C
45 lines
1.5 KiB
C
/* Copyright (c) 2009, 2010 Nicira Networks
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at:
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#ifndef OVSDB_LOG_H
|
|
#define OVSDB_LOG_H 1
|
|
|
|
#include <sys/types.h>
|
|
#include "compiler.h"
|
|
|
|
struct json;
|
|
struct ovsdb_log;
|
|
|
|
/* Access mode for opening an OVSDB log. */
|
|
enum ovsdb_log_open_mode {
|
|
OVSDB_LOG_READ_ONLY, /* Open existing file, read-only. */
|
|
OVSDB_LOG_READ_WRITE, /* Open existing file, read/write. */
|
|
OVSDB_LOG_CREATE /* Create new file, read/write. */
|
|
};
|
|
|
|
struct ovsdb_error *ovsdb_log_open(const char *name, enum ovsdb_log_open_mode,
|
|
int locking, struct ovsdb_log **)
|
|
WARN_UNUSED_RESULT;
|
|
void ovsdb_log_close(struct ovsdb_log *);
|
|
|
|
struct ovsdb_error *ovsdb_log_read(struct ovsdb_log *, struct json **)
|
|
WARN_UNUSED_RESULT;
|
|
struct ovsdb_error *ovsdb_log_write(struct ovsdb_log *, struct json *)
|
|
WARN_UNUSED_RESULT;
|
|
struct ovsdb_error *ovsdb_log_commit(struct ovsdb_log *)
|
|
WARN_UNUSED_RESULT;
|
|
|
|
#endif /* ovsdb/log.h */
|