X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=lib%2Fovsdb-idl-provider.h;h=7ea5ce6902d887ee6668d4e5fe45fd84a7e8fbad;hb=fe29af4c888d48cc1f16b1a247c2ffb6f0864522;hp=76197e8c3a6b8eba23e5494049b10bb105e6efc9;hpb=58fda1dab104041fc693032475ec4662c1a52849;p=sliver-openvswitch.git diff --git a/lib/ovsdb-idl-provider.h b/lib/ovsdb-idl-provider.h index 76197e8c3..7ea5ce690 100644 --- a/lib/ovsdb-idl-provider.h +++ b/lib/ovsdb-idl-provider.h @@ -1,4 +1,4 @@ -/* Copyright (c) 2009 Nicira Networks. +/* Copyright (c) 2009, 2010, 2011, 2012 Nicira, Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -29,31 +29,43 @@ struct ovsdb_idl_row { struct list src_arcs; /* Forward arcs (ovsdb_idl_arc.src_node). */ struct list dst_arcs; /* Backward arcs (ovsdb_idl_arc.dst_node). */ struct ovsdb_idl_table *table; /* Containing table. */ - struct ovsdb_datum *fields; /* Row data, or null if orphaned. */ + struct ovsdb_datum *old; /* Committed data (null if orphaned). */ + + /* Transactional data. */ + struct ovsdb_datum *new; /* Modified data (null to delete row). */ + unsigned long int *prereqs; /* Bitmap of columns to verify in "old". */ + unsigned long int *written; /* Bitmap of columns from "new" to write. */ + struct hmap_node txn_node; /* Node in ovsdb_idl_txn's list. */ }; struct ovsdb_idl_column { char *name; struct ovsdb_type type; + bool mutable; + void (*parse)(struct ovsdb_idl_row *, const struct ovsdb_datum *); + void (*unparse)(struct ovsdb_idl_row *); }; struct ovsdb_idl_table_class { char *name; + bool is_root; const struct ovsdb_idl_column *columns; size_t n_columns; size_t allocation_size; - void (*parse)(struct ovsdb_idl_row *); - void (*unparse)(struct ovsdb_idl_row *); + void (*row_init)(struct ovsdb_idl_row *); }; struct ovsdb_idl_table { const struct ovsdb_idl_table_class *class; + unsigned char *modes; /* OVSDB_IDL_* bitmasks, indexed by column. */ + bool need_table; /* Monitor table even if no columns? */ struct shash columns; /* Contains "const struct ovsdb_idl_column *"s. */ struct hmap rows; /* Contains "struct ovsdb_idl_row"s. */ struct ovsdb_idl *idl; /* Containing idl. */ }; struct ovsdb_idl_class { + const char *database; /* for this database. */ const struct ovsdb_idl_table_class *tables; size_t n_tables; }; @@ -63,9 +75,9 @@ struct ovsdb_idl_row *ovsdb_idl_get_row_arc( struct ovsdb_idl_table_class *dst_table, const struct uuid *dst_uuid); -struct ovsdb_idl_row *ovsdb_idl_first_row( - const struct ovsdb_idl *, const struct ovsdb_idl_table_class *); +void ovsdb_idl_txn_verify(const struct ovsdb_idl_row *, + const struct ovsdb_idl_column *); -struct ovsdb_idl_row *ovsdb_idl_next_row(const struct ovsdb_idl_row *); +struct ovsdb_idl_txn *ovsdb_idl_txn_get(const struct ovsdb_idl_row *); #endif /* ovsdb-idl-provider.h */