ovsdb-idl: Add support for change tracking.
[cascardo/ovs.git] / lib / ovsdb-idl-provider.h
1 /* Copyright (c) 2009, 2010, 2011, 2012 Nicira, Inc.
2  *
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at:
6  *
7  *     http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15
16 #ifndef OVSDB_IDL_PROVIDER_H
17 #define OVSDB_IDL_PROVIDER_H 1
18
19 #include "hmap.h"
20 #include "list.h"
21 #include "ovsdb-idl.h"
22 #include "ovsdb-types.h"
23 #include "shash.h"
24 #include "uuid.h"
25
26 struct ovsdb_idl_row {
27     struct hmap_node hmap_node; /* In struct ovsdb_idl_table's 'rows'. */
28     struct uuid uuid;           /* Row "_uuid" field. */
29     struct ovs_list src_arcs;   /* Forward arcs (ovsdb_idl_arc.src_node). */
30     struct ovs_list dst_arcs;   /* Backward arcs (ovsdb_idl_arc.dst_node). */
31     struct ovsdb_idl_table *table; /* Containing table. */
32     struct ovsdb_datum *old;    /* Committed data (null if orphaned). */
33
34     /* Transactional data. */
35     struct ovsdb_datum *new;    /* Modified data (null to delete row). */
36     unsigned long int *prereqs; /* Bitmap of columns to verify in "old". */
37     unsigned long int *written; /* Bitmap of columns from "new" to write. */
38     struct hmap_node txn_node;  /* Node in ovsdb_idl_txn's list. */
39
40     unsigned int change_seqno[OVSDB_IDL_CHANGE_MAX];
41     struct ovs_list track_node;
42 };
43
44 struct ovsdb_idl_column {
45     char *name;
46     struct ovsdb_type type;
47     bool mutable;
48     void (*parse)(struct ovsdb_idl_row *, const struct ovsdb_datum *);
49     void (*unparse)(struct ovsdb_idl_row *);
50 };
51
52 struct ovsdb_idl_table_class {
53     char *name;
54     bool is_root;
55     const struct ovsdb_idl_column *columns;
56     size_t n_columns;
57     size_t allocation_size;
58     void (*row_init)(struct ovsdb_idl_row *);
59 };
60
61 struct ovsdb_idl_table {
62     const struct ovsdb_idl_table_class *class;
63     unsigned char *modes;    /* OVSDB_IDL_* bitmasks, indexed by column. */
64     bool need_table;         /* Monitor table even if no columns? */
65     struct shash columns;    /* Contains "const struct ovsdb_idl_column *"s. */
66     struct hmap rows;        /* Contains "struct ovsdb_idl_row"s. */
67     struct ovsdb_idl *idl;   /* Containing idl. */
68     unsigned int change_seqno[OVSDB_IDL_CHANGE_MAX];
69     struct ovs_list track_list; /* Tracked rows (ovsdb_idl_row.track_node). */
70 };
71
72 struct ovsdb_idl_class {
73     const char *database;       /* <db-name> for this database. */
74     const struct ovsdb_idl_table_class *tables;
75     size_t n_tables;
76 };
77
78 struct ovsdb_idl_row *ovsdb_idl_get_row_arc(
79     struct ovsdb_idl_row *src,
80     struct ovsdb_idl_table_class *dst_table,
81     const struct uuid *dst_uuid);
82
83 void ovsdb_idl_txn_verify(const struct ovsdb_idl_row *,
84                           const struct ovsdb_idl_column *);
85
86 struct ovsdb_idl_txn *ovsdb_idl_txn_get(const struct ovsdb_idl_row *);
87
88 #endif /* ovsdb-idl-provider.h */