mirror of
https://github.com/openvswitch/ovs
synced 2025-08-30 22:05:19 +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>
71 lines
2.5 KiB
C
71 lines
2.5 KiB
C
/*
|
|
* Copyright (c) 2009, 2015 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 RTNETLINK_LINK_H
|
|
#define RTNETLINK_LINK_H 1
|
|
|
|
#include <stdbool.h>
|
|
#include <stdint.h>
|
|
#include <linux/if_ether.h>
|
|
|
|
#include "openvswitch/types.h"
|
|
|
|
struct ofpbuf;
|
|
struct nln_notifier;
|
|
|
|
/* These functions are Linux specific, so they should be used directly only by
|
|
* Linux-specific code. */
|
|
|
|
/* A digested version of an rtnetlink_link message sent down by the kernel to
|
|
* indicate that a network device's status (link or address) has been changed.
|
|
*/
|
|
struct rtnetlink_change {
|
|
/* Copied from struct nlmsghdr. */
|
|
int nlmsg_type; /* e.g. RTM_NEWLINK, RTM_DELLINK. */
|
|
|
|
/* Common attributes. */
|
|
int if_index; /* Index of network device. */
|
|
const char *ifname; /* Name of network device. */
|
|
|
|
/* Network device link status. */
|
|
int master_ifindex; /* Ifindex of datapath master (0 if none). */
|
|
int mtu; /* Current MTU. */
|
|
struct eth_addr mac;
|
|
unsigned int ifi_flags; /* Flags of network device. */
|
|
|
|
/* Network device address status. */
|
|
/* xxx To be added when needed. */
|
|
};
|
|
|
|
/* Function called to report that a netdev has changed. 'change' describes the
|
|
* specific change. It may be null if the buffer of change information
|
|
* overflowed, in which case the function must assume that every device may
|
|
* have changed. 'aux' is as specified in the call to
|
|
* rtnetlink_notifier_register(). */
|
|
typedef
|
|
void rtnetlink_notify_func(const struct rtnetlink_change *change,
|
|
void *aux);
|
|
|
|
bool rtnetlink_type_is_rtnlgrp_link(uint16_t type);
|
|
bool rtnetlink_type_is_rtnlgrp_addr(uint16_t type);
|
|
bool rtnetlink_parse(struct ofpbuf *buf, struct rtnetlink_change *change);
|
|
struct nln_notifier *
|
|
rtnetlink_notifier_create(rtnetlink_notify_func *, void *aux);
|
|
void rtnetlink_notifier_destroy(struct nln_notifier *);
|
|
void rtnetlink_run(void);
|
|
void rtnetlink_wait(void);
|
|
#endif /* rtnetlink.h */
|