@@ -4,6 +4,7 @@ openvswitchinclude_HEADERS = \
include/openvswitch/dynamic-string.h \
include/openvswitch/geneve.h \
include/openvswitch/list.h \
+ include/openvswitch/ofpbuf.h \
include/openvswitch/ofp-errors.h \
include/openvswitch/ofp-parse.h \
include/openvswitch/thread.h \
new file mode 100644
@@ -0,0 +1,277 @@
+/*
+ * Copyright (c) 2008, 2009, 2010, 2011, 2012, 2013, 2015, 2016 Nicira, Inc.
+ *
+ * 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 OPENVSWITCH_OFPBUF_H
+#define OPENVSWITCH_OFPBUF_H 1
+
+#include <stddef.h>
+#include <stdint.h>
+#include <stdlib.h>
+#include <string.h>
+#include "openvswitch/dynamic-string.h"
+#include "openvswitch/list.h"
+#include "openvswitch/util.h"
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+enum OVS_PACKED_ENUM ofpbuf_source {
+ OFPBUF_MALLOC, /* Obtained via malloc(). */
+ OFPBUF_STACK, /* Un-movable stack space or static buffer. */
+ OFPBUF_STUB, /* Starts on stack, may expand into heap. */
+};
+
+/* Buffer for holding arbitrary data. An ofpbuf is automatically reallocated
+ * as necessary if it grows too large for the available memory.
+ *
+ * 'header' and 'msg' conventions:
+ *
+ * OpenFlow messages: 'header' points to the start of the OpenFlow
+ * header, while 'msg' is the OpenFlow msg body.
+ * When parsing, the 'data' will move past these, as data is being
+ * pulled from the OpenFlow message.
+ *
+ * Caution: buffer manipulation of 'struct ofpbuf' must always update
+ * the 'header' and 'msg' pointers.
+ *
+ *
+ * Actions: When encoding OVS action lists, the 'header' is used
+ * as a pointer to the beginning of the current action (see ofpact_put()).
+ *
+ * rconn: Reuses 'header' as a private pointer while queuing.
+ */
+struct ofpbuf {
+ void *base; /* First byte of allocated space. */
+ void *data; /* First byte actually in use. */
+ uint32_t size; /* Number of bytes in use. */
+ uint32_t allocated; /* Number of bytes allocated. */
+
+ void *header; /* OpenFlow header. */
+ void *msg; /* message's body */
+ struct ovs_list list_node; /* Private list element for use by owner. */
+ enum ofpbuf_source source; /* Source of memory allocated as 'base'. */
+};
+
+/* An initializer for a struct ofpbuf that will be initially empty and uses the
+ * space in STUB (which should be an array) as a stub. This is the initializer
+ * form of ofpbuf_use_stub().
+ *
+ * Usage example:
+ *
+ * uint64_t stub[1024 / 8]; // 1 kB stub properly aligned for 64-bit data.
+ * struct ofpbuf ofpbuf = OFPBUF_STUB_INITIALIZER(stub);
+ */
+#define OFPBUF_STUB_INITIALIZER(STUB) { \
+ .base = (STUB), \
+ .data = (STUB), \
+ .size = 0, \
+ .allocated = sizeof (STUB), \
+ .header = NULL, \
+ .msg = NULL, \
+ .list_node = OVS_LIST_POISON, \
+ .source = OFPBUF_STUB, \
+ }
+
+/* An initializer for a struct ofpbuf whose data starts at DATA and continues
+ * for SIZE bytes. This is appropriate for an ofpbuf that will be used to
+ * inspect existing data, without moving it around or reallocating it, and
+ * generally without modifying it at all. This is the initializer form of
+ * ofpbuf_use_const().
+ */
+static inline struct ofpbuf
+ofpbuf_const_initializer(const void *data, size_t size)
+{
+ return (struct ofpbuf) {
+ .base = CONST_CAST(void *, data),
+ .data = CONST_CAST(void *, data),
+ .size = size,
+ .allocated = size,
+ .header = NULL,
+ .msg = NULL,
+ .list_node = OVS_LIST_POISON,
+ .source = OFPBUF_STACK,
+ };
+}
+
+void ofpbuf_use_ds(struct ofpbuf *, const struct ds *);
+void ofpbuf_use_stack(struct ofpbuf *, void *, size_t);
+void ofpbuf_use_stub(struct ofpbuf *, void *, size_t);
+void ofpbuf_use_const(struct ofpbuf *, const void *, size_t);
+
+void ofpbuf_init(struct ofpbuf *, size_t);
+void ofpbuf_uninit(struct ofpbuf *);
+void ofpbuf_reinit(struct ofpbuf *, size_t);
+
+struct ofpbuf *ofpbuf_new(size_t);
+struct ofpbuf *ofpbuf_new_with_headroom(size_t, size_t headroom);
+struct ofpbuf *ofpbuf_clone(const struct ofpbuf *);
+struct ofpbuf *ofpbuf_clone_with_headroom(const struct ofpbuf *,
+ size_t headroom);
+struct ofpbuf *ofpbuf_clone_data(const void *, size_t);
+struct ofpbuf *ofpbuf_clone_data_with_headroom(const void *, size_t,
+ size_t headroom);
+static inline void ofpbuf_delete(struct ofpbuf *);
+
+static inline void *ofpbuf_at(const struct ofpbuf *, size_t offset,
+ size_t size);
+static inline void *ofpbuf_at_assert(const struct ofpbuf *, size_t offset,
+ size_t size);
+static inline void *ofpbuf_tail(const struct ofpbuf *);
+static inline void *ofpbuf_end(const struct ofpbuf *);
+
+void *ofpbuf_put_uninit(struct ofpbuf *, size_t);
+void *ofpbuf_put_zeros(struct ofpbuf *, size_t);
+void *ofpbuf_put(struct ofpbuf *, const void *, size_t);
+char *ofpbuf_put_hex(struct ofpbuf *, const char *s, size_t *n);
+void ofpbuf_reserve(struct ofpbuf *, size_t);
+void *ofpbuf_push_uninit(struct ofpbuf *b, size_t);
+void *ofpbuf_push_zeros(struct ofpbuf *, size_t);
+void *ofpbuf_push(struct ofpbuf *b, const void *, size_t);
+
+static inline size_t ofpbuf_headroom(const struct ofpbuf *);
+static inline size_t ofpbuf_tailroom(const struct ofpbuf *);
+static inline size_t ofpbuf_msgsize(const struct ofpbuf *);
+void ofpbuf_prealloc_headroom(struct ofpbuf *, size_t);
+void ofpbuf_prealloc_tailroom(struct ofpbuf *, size_t);
+void ofpbuf_trim(struct ofpbuf *);
+void ofpbuf_padto(struct ofpbuf *, size_t);
+void ofpbuf_shift(struct ofpbuf *, int);
+
+static inline void ofpbuf_clear(struct ofpbuf *);
+static inline void *ofpbuf_pull(struct ofpbuf *, size_t);
+static inline void *ofpbuf_try_pull(struct ofpbuf *, size_t);
+
+void *ofpbuf_steal_data(struct ofpbuf *);
+
+char *ofpbuf_to_string(const struct ofpbuf *, size_t maxbytes);
+static inline struct ofpbuf *ofpbuf_from_list(const struct ovs_list *);
+void ofpbuf_list_delete(struct ovs_list *);
+static inline bool ofpbuf_equal(const struct ofpbuf *, const struct ofpbuf *);
+
+
+/* Frees memory that 'b' points to, as well as 'b' itself. */
+static inline void ofpbuf_delete(struct ofpbuf *b)
+{
+ if (b) {
+ ofpbuf_uninit(b);
+ free(b);
+ }
+}
+
+/* If 'b' contains at least 'offset + size' bytes of data, returns a pointer to
+ * byte 'offset'. Otherwise, returns a null pointer. */
+static inline void *ofpbuf_at(const struct ofpbuf *b, size_t offset,
+ size_t size)
+{
+ return offset + size <= b->size ? (char *) b->data + offset : NULL;
+}
+
+/* Returns a pointer to byte 'offset' in 'b', which must contain at least
+ * 'offset + size' bytes of data. */
+static inline void *ofpbuf_at_assert(const struct ofpbuf *b, size_t offset,
+ size_t size)
+{
+ ovs_assert(offset + size <= b->size);
+ return ((char *) b->data) + offset;
+}
+
+/* Returns a pointer to byte following the last byte of data in use in 'b'. */
+static inline void *ofpbuf_tail(const struct ofpbuf *b)
+{
+ return (char *) b->data + b->size;
+}
+
+/* Returns a pointer to byte following the last byte allocated for use (but
+ * not necessarily in use) in 'b'. */
+static inline void *ofpbuf_end(const struct ofpbuf *b)
+{
+ return (char *) b->base + b->allocated;
+}
+
+/* Returns the number of bytes of headroom in 'b', that is, the number of bytes
+ * of unused space in ofpbuf 'b' before the data that is in use. (Most
+ * commonly, the data in a ofpbuf is at its beginning, and thus the ofpbuf's
+ * headroom is 0.) */
+static inline size_t ofpbuf_headroom(const struct ofpbuf *b)
+{
+ return (char*)b->data - (char*)b->base;
+}
+
+/* Returns the number of bytes that may be appended to the tail end of ofpbuf
+ * 'b' before the ofpbuf must be reallocated. */
+static inline size_t ofpbuf_tailroom(const struct ofpbuf *b)
+{
+ return (char*)ofpbuf_end(b) - (char*)ofpbuf_tail(b);
+}
+
+/* Returns the number of bytes from 'b->header' to 'b->msg', that is, the
+ * length of 'b''s header. */
+static inline size_t
+ofpbuf_headersize(const struct ofpbuf *b)
+{
+ return (char *)b->msg - (char *)b->header;
+}
+
+/* Returns the number of bytes from 'b->msg' to 'b->data + b->size', that is,
+ * the length of the used space in 'b' starting from 'msg'. */
+static inline size_t
+ofpbuf_msgsize(const struct ofpbuf *b)
+{
+ return (char *)ofpbuf_tail(b) - (char *)b->msg;
+}
+
+/* Clears any data from 'b'. */
+static inline void ofpbuf_clear(struct ofpbuf *b)
+{
+ b->data = b->base;
+ b->size = 0;
+}
+
+/* Removes 'size' bytes from the head end of 'b', which must contain at least
+ * 'size' bytes of data. Returns the first byte of data removed. */
+static inline void *ofpbuf_pull(struct ofpbuf *b, size_t size)
+{
+ void *data = b->data;
+ b->data = (char*)b->data + size;
+ b->size = b->size - size;
+ return data;
+}
+
+/* If 'b' has at least 'size' bytes of data, removes that many bytes from the
+ * head end of 'b' and returns the first byte removed. Otherwise, returns a
+ * null pointer without modifying 'b'. */
+static inline void *ofpbuf_try_pull(struct ofpbuf *b, size_t size)
+{
+ return b->size >= size ? ofpbuf_pull(b, size) : NULL;
+}
+
+static inline struct ofpbuf *ofpbuf_from_list(const struct ovs_list *list)
+{
+ return CONTAINER_OF(list, struct ofpbuf, list_node);
+}
+
+static inline bool ofpbuf_equal(const struct ofpbuf *a, const struct ofpbuf *b)
+{
+ return a->size == b->size &&
+ memcmp(a->data, b->data, a->size) == 0;
+}
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* ofpbuf.h */
@@ -154,7 +154,6 @@ lib_libopenvswitch_la_SOURCES = \
lib/ofp-version-opt.h \
lib/ofp-version-opt.c \
lib/ofpbuf.c \
- lib/ofpbuf.h \
lib/ovs-atomic-c11.h \
lib/ovs-atomic-clang.h \
lib/ovs-atomic-flag-gcc4.7+.h \
@@ -33,7 +33,7 @@
#include "openvswitch/list.h"
#include "netdev.h"
#include "odp-util.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ovs-thread.h"
#include "openvswitch/types.h"
#include "packets.h"
@@ -25,7 +25,7 @@
#include "multipath.h"
#include "meta-flow.h"
#include "nx-match.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ofp-actions.h"
#include "ofp-util.h"
#include "openflow/nicira-ext.h"
@@ -39,7 +39,7 @@
#include "netdev-dpdk.h"
#include "netlink.h"
#include "odp-util.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ovs-numa.h"
#include "packets.h"
#include "shash.h"
@@ -53,7 +53,7 @@
#include "odp-execute.h"
#include "odp-util.h"
#include "ofp-print.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ovs-numa.h"
#include "ovs-rcu.h"
#include "packets.h"
@@ -45,7 +45,7 @@
#include "netlink-socket.h"
#include "netlink.h"
#include "odp-util.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "packets.h"
#include "poll-loop.h"
#include "random.h"
@@ -35,7 +35,7 @@
#include "odp-util.h"
#include "ofp-print.h"
#include "ofp-util.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "packets.h"
#include "poll-loop.h"
#include "route-table.h"
@@ -25,7 +25,7 @@
#include "fatal-signal.h"
#include "json.h"
#include "openvswitch/list.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ovs-thread.h"
#include "poll-loop.h"
#include "reconnect.h"
@@ -26,7 +26,7 @@
#include "nx-match.h"
#include "ofp-actions.h"
#include "ofp-util.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "openflow/openflow.h"
#include "openvswitch/ofp-errors.h"
#include "unaligned.h"
@@ -29,7 +29,7 @@
#include "flow.h"
#include "hmap.h"
#include "mac-learning.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ofp-actions.h"
#include "ofp-msgs.h"
#include "ofp-print.h"
@@ -29,7 +29,7 @@
#include "netdev-vport.h"
#include "odp-util.h"
#include "ofp-print.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ovs-atomic.h"
#include "packets.h"
#include "pcap-file.h"
@@ -61,7 +61,7 @@
#include "netlink-notifier.h"
#include "netlink-socket.h"
#include "netlink.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "openflow/openflow.h"
#include "ovs-atomic.h"
#include "packets.h"
@@ -24,7 +24,7 @@
#include "coverage.h"
#include "fatal-signal.h"
#include "netdev-provider.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "packets.h"
#include "poll-loop.h"
#include "shash.h"
@@ -30,7 +30,7 @@
#include "openvswitch/dynamic-string.h"
#include "netlink.h"
#include "netlink-socket.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "openvswitch/vlog.h"
#include "poll-loop.h"
#include "timeval.h"
@@ -22,7 +22,7 @@
#include "ct-dpif.h"
#include "openvswitch/dynamic-string.h"
#include "hmap.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "timeval.h"
#include "unixctl.h"
#include "util.h"
@@ -25,7 +25,7 @@
#include "coverage.h"
#include "netlink.h"
#include "netlink-socket.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "openvswitch/vlog.h"
VLOG_DEFINE_THIS_MODULE(netlink_notifier);
@@ -29,7 +29,7 @@
#include "netlink.h"
#include "netlink-protocol.h"
#include "odp-netlink.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ovs-thread.h"
#include "poll-loop.h"
#include "seq.h"
@@ -193,7 +193,7 @@
#include <stdbool.h>
#include <stddef.h>
#include <stdint.h>
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ovs-atomic.h"
#include "ovs-thread.h"
@@ -23,7 +23,7 @@
#include "coverage.h"
#include "flow.h"
#include "netlink-protocol.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "timeval.h"
#include "unaligned.h"
#include "openvswitch/vlog.h"
@@ -27,7 +27,7 @@
#include "meta-flow.h"
#include "ofp-actions.h"
#include "ofp-util.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "openflow/nicira-ext.h"
#include "packets.h"
#include "shash.h"
@@ -32,7 +32,7 @@
#include "openvswitch/dynamic-string.h"
#include "flow.h"
#include "netlink.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "packets.h"
#include "simap.h"
#include "timeval.h"
@@ -32,7 +32,7 @@
#include "odp-netlink.h"
#include "ofp-prop.h"
#include "ofp-util.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "unaligned.h"
#include "util.h"
#include "openvswitch/ofp-parse.h"
@@ -20,7 +20,7 @@
#include "openvswitch/dynamic-string.h"
#include "ofp-msgs.h"
#include "ofp-util.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "openflow/openflow.h"
#include "openvswitch/ofp-errors.h"
#include "openvswitch/vlog.h"
@@ -20,7 +20,7 @@
#include "openvswitch/dynamic-string.h"
#include "hash.h"
#include "hmap.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "openflow/nicira-ext.h"
#include "openflow/openflow.h"
#include "ovs-thread.h"
@@ -30,7 +30,7 @@
#include "nx-match.h"
#include "ofp-actions.h"
#include "ofp-util.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "openflow/openflow.h"
#include "ovs-thread.h"
#include "packets.h"
@@ -38,7 +38,7 @@
#include "netdev.h"
#include "nx-match.h"
#include "ofp-actions.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ofp-msgs.h"
#include "ofp-util.h"
#include "openflow/openflow.h"
@@ -19,7 +19,7 @@
#include "ofp-prop.h"
#include "byte-order.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "openvswitch/ofp-errors.h"
#include "openvswitch/vlog.h"
#include "util.h"
@@ -37,7 +37,7 @@
#include "ofp-msgs.h"
#include "ofp-prop.h"
#include "ofp-util.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "openflow/netronome-ext.h"
#include "packets.h"
#include "pktbuf.h"
@@ -15,7 +15,7 @@
*/
#include <config.h>
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include <stdlib.h>
#include <string.h>
#include "openvswitch/dynamic-string.h"
deleted file mode 100644
@@ -1,275 +0,0 @@
-/*
- * Copyright (c) 2008, 2009, 2010, 2011, 2012, 2013, 2015, 2016 Nicira, Inc.
- *
- * 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 OFPBUF_H
-#define OFPBUF_H 1
-
-#include <stddef.h>
-#include <stdint.h>
-#include "openvswitch/list.h"
-#include "packets.h"
-#include "util.h"
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-enum OVS_PACKED_ENUM ofpbuf_source {
- OFPBUF_MALLOC, /* Obtained via malloc(). */
- OFPBUF_STACK, /* Un-movable stack space or static buffer. */
- OFPBUF_STUB, /* Starts on stack, may expand into heap. */
-};
-
-/* Buffer for holding arbitrary data. An ofpbuf is automatically reallocated
- * as necessary if it grows too large for the available memory.
- *
- * 'header' and 'msg' conventions:
- *
- * OpenFlow messages: 'header' points to the start of the OpenFlow
- * header, while 'msg' is the OpenFlow msg body.
- * When parsing, the 'data' will move past these, as data is being
- * pulled from the OpenFlow message.
- *
- * Caution: buffer manipulation of 'struct ofpbuf' must always update
- * the 'header' and 'msg' pointers.
- *
- *
- * Actions: When encoding OVS action lists, the 'header' is used
- * as a pointer to the beginning of the current action (see ofpact_put()).
- *
- * rconn: Reuses 'header' as a private pointer while queuing.
- */
-struct ofpbuf {
- void *base; /* First byte of allocated space. */
- void *data; /* First byte actually in use. */
- uint32_t size; /* Number of bytes in use. */
- uint32_t allocated; /* Number of bytes allocated. */
-
- void *header; /* OpenFlow header. */
- void *msg; /* message's body */
- struct ovs_list list_node; /* Private list element for use by owner. */
- enum ofpbuf_source source; /* Source of memory allocated as 'base'. */
-};
-
-/* An initializer for a struct ofpbuf that will be initially empty and uses the
- * space in STUB (which should be an array) as a stub. This is the initializer
- * form of ofpbuf_use_stub().
- *
- * Usage example:
- *
- * uint64_t stub[1024 / 8]; // 1 kB stub properly aligned for 64-bit data.
- * struct ofpbuf ofpbuf = OFPBUF_STUB_INITIALIZER(stub);
- */
-#define OFPBUF_STUB_INITIALIZER(STUB) { \
- .base = (STUB), \
- .data = (STUB), \
- .size = 0, \
- .allocated = sizeof (STUB), \
- .header = NULL, \
- .msg = NULL, \
- .list_node = OVS_LIST_POISON, \
- .source = OFPBUF_STUB, \
- }
-
-/* An initializer for a struct ofpbuf whose data starts at DATA and continues
- * for SIZE bytes. This is appropriate for an ofpbuf that will be used to
- * inspect existing data, without moving it around or reallocating it, and
- * generally without modifying it at all. This is the initializer form of
- * ofpbuf_use_const().
- */
-static inline struct ofpbuf
-ofpbuf_const_initializer(const void *data, size_t size)
-{
- return (struct ofpbuf) {
- .base = CONST_CAST(void *, data),
- .data = CONST_CAST(void *, data),
- .size = size,
- .allocated = size,
- .header = NULL,
- .msg = NULL,
- .list_node = OVS_LIST_POISON,
- .source = OFPBUF_STACK,
- };
-}
-
-void ofpbuf_use_ds(struct ofpbuf *, const struct ds *);
-void ofpbuf_use_stack(struct ofpbuf *, void *, size_t);
-void ofpbuf_use_stub(struct ofpbuf *, void *, size_t);
-void ofpbuf_use_const(struct ofpbuf *, const void *, size_t);
-
-void ofpbuf_init(struct ofpbuf *, size_t);
-void ofpbuf_uninit(struct ofpbuf *);
-void ofpbuf_reinit(struct ofpbuf *, size_t);
-
-struct ofpbuf *ofpbuf_new(size_t);
-struct ofpbuf *ofpbuf_new_with_headroom(size_t, size_t headroom);
-struct ofpbuf *ofpbuf_clone(const struct ofpbuf *);
-struct ofpbuf *ofpbuf_clone_with_headroom(const struct ofpbuf *,
- size_t headroom);
-struct ofpbuf *ofpbuf_clone_data(const void *, size_t);
-struct ofpbuf *ofpbuf_clone_data_with_headroom(const void *, size_t,
- size_t headroom);
-static inline void ofpbuf_delete(struct ofpbuf *);
-
-static inline void *ofpbuf_at(const struct ofpbuf *, size_t offset,
- size_t size);
-static inline void *ofpbuf_at_assert(const struct ofpbuf *, size_t offset,
- size_t size);
-static inline void *ofpbuf_tail(const struct ofpbuf *);
-static inline void *ofpbuf_end(const struct ofpbuf *);
-
-void *ofpbuf_put_uninit(struct ofpbuf *, size_t);
-void *ofpbuf_put_zeros(struct ofpbuf *, size_t);
-void *ofpbuf_put(struct ofpbuf *, const void *, size_t);
-char *ofpbuf_put_hex(struct ofpbuf *, const char *s, size_t *n);
-void ofpbuf_reserve(struct ofpbuf *, size_t);
-void *ofpbuf_push_uninit(struct ofpbuf *b, size_t);
-void *ofpbuf_push_zeros(struct ofpbuf *, size_t);
-void *ofpbuf_push(struct ofpbuf *b, const void *, size_t);
-
-static inline size_t ofpbuf_headroom(const struct ofpbuf *);
-static inline size_t ofpbuf_tailroom(const struct ofpbuf *);
-static inline size_t ofpbuf_msgsize(const struct ofpbuf *);
-void ofpbuf_prealloc_headroom(struct ofpbuf *, size_t);
-void ofpbuf_prealloc_tailroom(struct ofpbuf *, size_t);
-void ofpbuf_trim(struct ofpbuf *);
-void ofpbuf_padto(struct ofpbuf *, size_t);
-void ofpbuf_shift(struct ofpbuf *, int);
-
-static inline void ofpbuf_clear(struct ofpbuf *);
-static inline void *ofpbuf_pull(struct ofpbuf *, size_t);
-static inline void *ofpbuf_try_pull(struct ofpbuf *, size_t);
-
-void *ofpbuf_steal_data(struct ofpbuf *);
-
-char *ofpbuf_to_string(const struct ofpbuf *, size_t maxbytes);
-static inline struct ofpbuf *ofpbuf_from_list(const struct ovs_list *);
-void ofpbuf_list_delete(struct ovs_list *);
-static inline bool ofpbuf_equal(const struct ofpbuf *, const struct ofpbuf *);
-
-
-/* Frees memory that 'b' points to, as well as 'b' itself. */
-static inline void ofpbuf_delete(struct ofpbuf *b)
-{
- if (b) {
- ofpbuf_uninit(b);
- free(b);
- }
-}
-
-/* If 'b' contains at least 'offset + size' bytes of data, returns a pointer to
- * byte 'offset'. Otherwise, returns a null pointer. */
-static inline void *ofpbuf_at(const struct ofpbuf *b, size_t offset,
- size_t size)
-{
- return offset + size <= b->size ? (char *) b->data + offset : NULL;
-}
-
-/* Returns a pointer to byte 'offset' in 'b', which must contain at least
- * 'offset + size' bytes of data. */
-static inline void *ofpbuf_at_assert(const struct ofpbuf *b, size_t offset,
- size_t size)
-{
- ovs_assert(offset + size <= b->size);
- return ((char *) b->data) + offset;
-}
-
-/* Returns a pointer to byte following the last byte of data in use in 'b'. */
-static inline void *ofpbuf_tail(const struct ofpbuf *b)
-{
- return (char *) b->data + b->size;
-}
-
-/* Returns a pointer to byte following the last byte allocated for use (but
- * not necessarily in use) in 'b'. */
-static inline void *ofpbuf_end(const struct ofpbuf *b)
-{
- return (char *) b->base + b->allocated;
-}
-
-/* Returns the number of bytes of headroom in 'b', that is, the number of bytes
- * of unused space in ofpbuf 'b' before the data that is in use. (Most
- * commonly, the data in a ofpbuf is at its beginning, and thus the ofpbuf's
- * headroom is 0.) */
-static inline size_t ofpbuf_headroom(const struct ofpbuf *b)
-{
- return (char*)b->data - (char*)b->base;
-}
-
-/* Returns the number of bytes that may be appended to the tail end of ofpbuf
- * 'b' before the ofpbuf must be reallocated. */
-static inline size_t ofpbuf_tailroom(const struct ofpbuf *b)
-{
- return (char*)ofpbuf_end(b) - (char*)ofpbuf_tail(b);
-}
-
-/* Returns the number of bytes from 'b->header' to 'b->msg', that is, the
- * length of 'b''s header. */
-static inline size_t
-ofpbuf_headersize(const struct ofpbuf *b)
-{
- return (char *)b->msg - (char *)b->header;
-}
-
-/* Returns the number of bytes from 'b->msg' to 'b->data + b->size', that is,
- * the length of the used space in 'b' starting from 'msg'. */
-static inline size_t
-ofpbuf_msgsize(const struct ofpbuf *b)
-{
- return (char *)ofpbuf_tail(b) - (char *)b->msg;
-}
-
-/* Clears any data from 'b'. */
-static inline void ofpbuf_clear(struct ofpbuf *b)
-{
- b->data = b->base;
- b->size = 0;
-}
-
-/* Removes 'size' bytes from the head end of 'b', which must contain at least
- * 'size' bytes of data. Returns the first byte of data removed. */
-static inline void *ofpbuf_pull(struct ofpbuf *b, size_t size)
-{
- void *data = b->data;
- b->data = (char*)b->data + size;
- b->size = b->size - size;
- return data;
-}
-
-/* If 'b' has at least 'size' bytes of data, removes that many bytes from the
- * head end of 'b' and returns the first byte removed. Otherwise, returns a
- * null pointer without modifying 'b'. */
-static inline void *ofpbuf_try_pull(struct ofpbuf *b, size_t size)
-{
- return b->size >= size ? ofpbuf_pull(b, size) : NULL;
-}
-
-static inline struct ofpbuf *ofpbuf_from_list(const struct ovs_list *list)
-{
- return CONTAINER_OF(list, struct ofpbuf, list_node);
-}
-
-static inline bool ofpbuf_equal(const struct ofpbuf *a, const struct ofpbuf *b)
-{
- return a->size == b->size &&
- memcmp(a->data, b->data, a->size) == 0;
-}
-
-#ifdef __cplusplus
-}
-#endif
-
-#endif /* ofpbuf.h */
@@ -23,7 +23,7 @@
#include "coverage.h"
#include "ofp-msgs.h"
#include "ofp-util.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "openflow/openflow.h"
#include "poll-loop.h"
#include "sat-math.h"
@@ -28,7 +28,7 @@
#include "netlink.h"
#include "netlink-notifier.h"
#include "netlink-socket.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ovs-router.h"
#include "packets.h"
#include "rtnetlink.h"
@@ -38,7 +38,7 @@
#include <sys/types.h>
#include "byte-order.h"
#include "connectivity.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "dp-packet.h"
#include "packets.h"
#include "seq.h"
@@ -39,7 +39,7 @@
#include <sys/types.h>
#include "byte-order.h"
#include "connectivity.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ofproto/ofproto.h"
#include "dp-packet.h"
#include "packets.h"
@@ -24,7 +24,8 @@
#include "netlink.h"
#include "netlink-notifier.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
+#include "packets.h"
static struct nln *nln = NULL;
static struct rtnetlink_change rtn_change;
@@ -27,7 +27,7 @@
#include <stdlib.h>
#include "byte-order.h"
#include "connectivity.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ovs-atomic.h"
#include "dp-packet.h"
#include "packets.h"
@@ -35,7 +35,7 @@
#include "coverage.h"
#include "openvswitch/dynamic-string.h"
#include "entropy.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "openflow/openflow.h"
#include "packets.h"
#include "poll-loop.h"
@@ -28,7 +28,7 @@
#include "flow.h"
#include "jsonrpc.h"
#include "ofp-print.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "openflow/nicira-ext.h"
#include "openflow/openflow.h"
#include "ovs-thread.h"
@@ -27,7 +27,7 @@
#include "hash.h"
#include "openvswitch/list.h"
#include "netdev.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ovs-thread.h"
#include "odp-util.h"
#include "ovs-thread.h"
@@ -21,7 +21,7 @@
#include "openvswitch/dynamic-string.h"
#include "netlink.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "openflow/openflow.h"
#include "openvswitch/geneve.h"
@@ -22,7 +22,7 @@
#include <sys/types.h>
#include <unistd.h>
#include "fatal-signal.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "openflow/openflow.h"
#include "poll-loop.h"
#include "socket-util.h"
@@ -29,7 +29,7 @@
#include "ofp-msgs.h"
#include "ofp-print.h"
#include "ofp-util.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "openflow/nicira-ext.h"
#include "openflow/openflow.h"
#include "packets.h"
@@ -32,7 +32,7 @@
#include "coverage.h"
#include "dirs.h"
#include "openvswitch/dynamic-string.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ovs-thread.h"
#include "sat-math.h"
#include "socket-util.h"
@@ -25,7 +25,7 @@
#include "ofp-util.h"
#include "ofp-actions.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ofproto/ofproto-provider.h"
#include "ofproto/ofproto-dpif.h"
#include "ofproto/ofproto-dpif-rid.h"
@@ -38,7 +38,7 @@
#include "openvswitch/list.h"
#include "netdev.h"
#include "odp-util.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "packets.h"
#include "dp-packet.h"
#include "poll-loop.h"
@@ -25,7 +25,7 @@
#include "ofp-actions.h"
#include "ofp-msgs.h"
#include "ofp-util.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ofproto-provider.h"
#include "pinsched.h"
#include "poll-loop.h"
@@ -29,7 +29,7 @@
#include "ofp-actions.h"
#include "ofp-msgs.h"
#include "ofp-util.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ofproto-provider.h"
#include "pinsched.h"
#include "poll-loop.h"
@@ -23,7 +23,7 @@
#include "flow.h"
#include "mac-learning.h"
#include "odp-util.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ofp-actions.h"
#include "ofp-util.h"
#include "ofproto.h"
@@ -31,7 +31,7 @@
#include "odp-util.h"
#include "ofp-actions.h"
#include "ofproto.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ofproto-provider.h"
#include "openflow/openflow.h"
#include "packets.h"
@@ -25,7 +25,7 @@
#include "dpif.h"
#include "flow.h"
#include "lib/netflow.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ofproto.h"
#include "ofproto/netflow.h"
#include "packets.h"
@@ -23,7 +23,7 @@
#include "hash.h"
#include "hmap.h"
#include "openvswitch/list.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ofproto.h"
#include "ofproto-dpif.h"
#include "dp-packet.h"
@@ -27,7 +27,7 @@
#include "heap.h"
#include "hmap.h"
#include "latch.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ofproto-dpif.h"
#include "ovs-lldp.h"
#include "ovs-thread.h"
@@ -16,7 +16,7 @@
#include <config.h>
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ofproto-dpif.h"
#include "ofproto-dpif-rid.h"
#include "ofproto-provider.h"
@@ -29,7 +29,7 @@
#include "hmap.h"
#include "netdev.h"
#include "netlink.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ofproto.h"
#include "packets.h"
#include "poll-loop.h"
@@ -29,7 +29,7 @@
#include "latch.h"
#include "openvswitch/list.h"
#include "netlink.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ofproto-dpif-ipfix.h"
#include "ofproto-dpif-sflow.h"
#include "ofproto-dpif-xlate.h"
@@ -19,7 +19,7 @@
#include "flow.h"
#include "meta-flow.h"
#include "odp-util.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ofproto-dpif-mirror.h"
#include "ofproto-dpif-rid.h"
#include "ofproto-dpif.h"
@@ -48,7 +48,7 @@
#include "odp-util.h"
#include "odp-execute.h"
#include "ofp-util.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ofp-actions.h"
#include "ofp-print.h"
#include "ofproto-dpif-ipfix.h"
@@ -38,7 +38,7 @@
#include "ofp-msgs.h"
#include "ofp-print.h"
#include "ofp-util.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ofproto-provider.h"
#include "openflow/nicira-ext.h"
#include "openflow/openflow.h"
@@ -24,7 +24,7 @@
#include "flow.h"
#include "hash.h"
#include "hmap.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "openflow/openflow.h"
#include "poll-loop.h"
#include "random.h"
@@ -27,7 +27,7 @@
#include "hmap.h"
#include "netdev.h"
#include "odp-util.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "packets.h"
#include "route-table.h"
#include "seq.h"
@@ -19,7 +19,7 @@
#include "openvswitch/dynamic-string.h"
#include "ofctrl.h"
#include "ofp-actions.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "openvswitch/vlog.h"
#include "ovn-controller.h"
#include "ovn/lib/actions.h"
@@ -23,7 +23,7 @@
#include "ofp-msgs.h"
#include "ofp-print.h"
#include "ofp-util.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "openflow/openflow.h"
#include "openvswitch/vlog.h"
#include "ovn-controller.h"
@@ -19,7 +19,7 @@
#include "match.h"
#include "ofctrl.h"
#include "ofp-actions.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ovn-controller.h"
#include "ovn/lib/ovn-sb-idl.h"
#include "openvswitch/vlog.h"
@@ -24,7 +24,7 @@
#include "lex.h"
#include "logical-fields.h"
#include "ofp-actions.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "simap.h"
/* Context maintained during actions_parse(). */
@@ -20,7 +20,7 @@
#include <stdlib.h>
#include "flow.h"
#include "ofp-actions.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ovstest.h"
#include "util.h"
@@ -22,7 +22,7 @@
#include <stdlib.h>
#include <string.h>
#include "classifier.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ofp-print.h"
#include "ofp-util.h"
#include "openflow/openflow.h"
@@ -21,6 +21,7 @@
#undef NDEBUG
#include "openvswitch/list.h"
#include <assert.h>
+#include <stdio.h>
#include <string.h>
#include "ovstest.h"
@@ -25,7 +25,7 @@
#include "command-line.h"
#include "daemon.h"
#include "openvswitch/dynamic-string.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ovstest.h"
#include "packets.h"
#include "poll-loop.h"
@@ -21,7 +21,7 @@
#include "openvswitch/dynamic-string.h"
#include "flow.h"
#include "match.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ovstest.h"
#include "util.h"
#include "openvswitch/ofp-parse.h"
@@ -17,7 +17,7 @@
#include <config.h>
#undef NDEBUG
#include <stdio.h>
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ovstest.h"
#include "util.h"
@@ -23,7 +23,7 @@
#include "fatal-signal.h"
#include "match.h"
#include "ofp-actions.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ovn/lib/actions.h"
#include "ovn/lib/expr.h"
#include "ovn/lib/lex.h"
@@ -7,7 +7,7 @@
#include <inttypes.h>
#include <stdarg.h>
#include <stdlib.h>
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ovstest.h"
#include "dp-packet.h"
#include "packets.h"
@@ -28,7 +28,7 @@
#include "command-line.h"
#include "daemon.h"
#include "openvswitch/dynamic-string.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ovstest.h"
#include "packets.h"
#include "poll-loop.h"
@@ -24,7 +24,7 @@
#include <stdarg.h>
#include <stdlib.h>
#include "dp-packet.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ovstest.h"
#include "packets.h"
#include "openvswitch/vlog.h"
@@ -27,7 +27,7 @@
#include "fatal-signal.h"
#include "ofp-msgs.h"
#include "ofp-util.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "openflow/openflow.h"
#include "ovstest.h"
#include "poll-loop.h"
@@ -25,7 +25,7 @@
#include <linux/rtnetlink.h>
#include "netlink.h"
#include "netlink-socket.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "poll-loop.h"
#include "timeval.h"
#include "util.h"
@@ -45,7 +45,7 @@
#include "ofp-print.h"
#include "ofp-util.h"
#include "ofp-version-opt.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ofproto/ofproto.h"
#include "openflow/nicira-ext.h"
#include "openflow/openflow.h"
@@ -30,7 +30,7 @@
#include "fatal-signal.h"
#include "learning-switch.h"
#include "ofp-version-opt.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "openflow/openflow.h"
#include "poll-loop.h"
#include "rconn.h"
@@ -43,7 +43,7 @@
#include "nx-match.h"
#include "ofp-print.h"
#include "ofp-util.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ofproto/bond.h"
#include "ofproto/ofproto.h"
#include "ovs-numa.h"
@@ -36,7 +36,7 @@
#include "openvswitch/dynamic-string.h"
#include "json.h"
#include "latch.h"
-#include "ofpbuf.h"
+#include "openvswitch/ofpbuf.h"
#include "ovs-thread.h"
#include "poll-loop.h"
#include "shash.h"