mirror of
https://github.com/openvswitch/ovs
synced 2025-09-05 08:45:23 +00:00
datapath-protocol: Use Linux kernel types directly.
We want datapath-protocol.h to be acceptable as a Linux kernel header, so it must use Linux kernel types and must not have references to Open vSwitch symbols or header files. This commit primarily makes that change to datapath-protocol.h. At the same time, at least for now we also want datapath-protocol.h to be usable on non-Linux platforms, so we need some kind of compatiblity. Thus, this commit also introduces a <linux/types.h> header file that defines the necessary Linux kernel types on non-Linux platforms. In turn, this requires openvswitch/types.h to use the Linux types directly for ovs_be<N>; otherwise, sparse complains because now __be<N> and ovs_be<N> are incompatible from its perspective, so this commit makes that change too. I don't have a non-Linux kernel platform readily available, so I only tested the non-Linux part of the linux/types.h substitute by forcing that case to be triggered with #if 0. It worked, except for errors in actual Linux kernel headers included explicitly from OVS source files, so I think it's likely to work in practice. Bug #7559. Signed-off-by: Ben Pfaff <blp@nicira.com> Acked-by: Jesse Gross <jesse@nicira.com>
This commit is contained in:
@@ -17,6 +17,7 @@
|
||||
#ifndef OPENVSWITCH_TYPES_H
|
||||
#define OPENVSWITCH_TYPES_H 1
|
||||
|
||||
#include <linux/types.h>
|
||||
#include <sys/types.h>
|
||||
#include <stdint.h>
|
||||
|
||||
@@ -31,11 +32,12 @@
|
||||
/* The ovs_be<N> types indicate that an object is in big-endian, not
|
||||
* native-endian, byte order. They are otherwise equivalent to uint<N>_t.
|
||||
*
|
||||
* The OVS_BITWISE annotation allows the sparse checker to issue warnings
|
||||
* for incorrect use of values in network byte order. */
|
||||
typedef uint16_t OVS_BITWISE ovs_be16;
|
||||
typedef uint32_t OVS_BITWISE ovs_be32;
|
||||
typedef uint64_t OVS_BITWISE ovs_be64;
|
||||
* We bootstrap these from the Linux __be<N> types. If we instead define our
|
||||
* own independently then __be<N> and ovs_be<N> become mutually
|
||||
* incompatible. */
|
||||
typedef __be16 ovs_be16;
|
||||
typedef __be32 ovs_be32;
|
||||
typedef __be64 ovs_be64;
|
||||
|
||||
/* Netlink and OpenFlow both contain 64-bit values that are only guaranteed to
|
||||
* be aligned on 32-bit boundaries. These types help.
|
||||
|
Reference in New Issue
Block a user