mirror of
https://github.com/openvswitch/ovs
synced 2025-10-15 14:17:18 +00:00
Define struct eth_addr and use it instead of a uint8_t array for all ethernet addresses in OVS userspace. The struct is always the right size, and it can be assigned without an explicit memcpy, which makes code more readable. "struct eth_addr" is a good type name for this as many utility functions are already named accordingly. struct eth_addr can be accessed as bytes as well as ovs_be16's, which makes the struct 16-bit aligned. All use seems to be 16-bit aligned, so some algorithms on the ethernet addresses can be made a bit more efficient making use of this fact. As the struct fits into a register (in 64-bit systems) we pass it by value when possible. This patch also changes the few uses of Linux specific ETH_ALEN to OVS's own ETH_ADDR_LEN, and removes the OFP_ETH_ALEN, as it is no longer needed. This work stemmed from a desire to make all struct flow members assignable for unrelated exploration purposes. However, I think this might be a nice code readability improvement by itself. Signed-off-by: Jarno Rajahalme <jrajahalme@nicira.com>
60 lines
1.9 KiB
C
60 lines
1.9 KiB
C
/* Copyright (c) 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.
|
|
* 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 BFD_H
|
|
#define BFD_H 1
|
|
|
|
#define BFD_PACKET_LEN 24
|
|
#define BFD_DEST_PORT 3784
|
|
|
|
#include <stdbool.h>
|
|
#include <inttypes.h>
|
|
|
|
#include "packets.h"
|
|
|
|
struct bfd;
|
|
struct dpif_flow_stats;
|
|
struct flow;
|
|
struct flow_wildcards;
|
|
struct netdev;
|
|
struct dp_packet;
|
|
struct smap;
|
|
|
|
long long int bfd_wait(const struct bfd *);
|
|
void bfd_run(struct bfd *);
|
|
|
|
bool bfd_should_send_packet(const struct bfd *);
|
|
void bfd_put_packet(struct bfd *bfd, struct dp_packet *packet,
|
|
const struct eth_addr eth_src);
|
|
|
|
bool bfd_should_process_flow(const struct bfd *, const struct flow *,
|
|
struct flow_wildcards *);
|
|
void bfd_process_packet(struct bfd *, const struct flow *,
|
|
const struct dp_packet *);
|
|
|
|
void bfd_init(void);
|
|
struct bfd *bfd_configure(struct bfd *, const char *name,
|
|
const struct smap *smap,
|
|
struct netdev *netdev);
|
|
struct bfd *bfd_ref(const struct bfd *);
|
|
void bfd_unref(struct bfd *);
|
|
|
|
void bfd_account_rx(struct bfd *, const struct dpif_flow_stats *);
|
|
bool bfd_forwarding(struct bfd *);
|
|
bool bfd_check_status_change(struct bfd *);
|
|
void bfd_get_status(const struct bfd *, struct smap *);
|
|
void bfd_set_netdev(struct bfd *, const struct netdev *);
|
|
long long int bfd_wake_time(const struct bfd *);
|
|
#endif /* bfd.h */
|