da5350ef29
The ether header does not need to be packed since that makes no sense for structures with only bytes in them, but it should be aligned to a two-byte boundary to simplify access to it from code. Other packed structures that use this also need to be updated to take account of the change, either by removing packing - where it is clearly unneeded - or by explicitly giving those structures 2-byte alignment also. Signed-off-by: Stephen Hemminger <stephen@networkplumber.org> Signed-off-by: Bruce Richardson <bruce.richardson@intel.com>
76 lines
1.9 KiB
C
76 lines
1.9 KiB
C
/* SPDX-License-Identifier: BSD-3-Clause
|
|
* Copyright(c) 2013 6WIND S.A.
|
|
*/
|
|
|
|
#ifndef _RTE_ARP_H_
|
|
#define _RTE_ARP_H_
|
|
|
|
/**
|
|
* @file
|
|
*
|
|
* ARP-related defines
|
|
*/
|
|
|
|
#include <stdint.h>
|
|
#include <rte_ether.h>
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* ARP header IPv4 payload.
|
|
*/
|
|
struct rte_arp_ipv4 {
|
|
struct rte_ether_addr arp_sha; /**< sender hardware address */
|
|
uint32_t arp_sip; /**< sender IP address */
|
|
struct rte_ether_addr arp_tha; /**< target hardware address */
|
|
uint32_t arp_tip; /**< target IP address */
|
|
} __attribute__((__packed__)) __attribute__((aligned(2)));
|
|
|
|
/**
|
|
* ARP header.
|
|
*/
|
|
struct rte_arp_hdr {
|
|
uint16_t arp_hardware; /* format of hardware address */
|
|
#define RTE_ARP_HRD_ETHER 1 /* ARP Ethernet address format */
|
|
|
|
uint16_t arp_protocol; /* format of protocol address */
|
|
uint8_t arp_hlen; /* length of hardware address */
|
|
uint8_t arp_plen; /* length of protocol address */
|
|
uint16_t arp_opcode; /* ARP opcode (command) */
|
|
#define RTE_ARP_OP_REQUEST 1 /* request to resolve address */
|
|
#define RTE_ARP_OP_REPLY 2 /* response to previous request */
|
|
#define RTE_ARP_OP_REVREQUEST 3 /* request proto addr given hardware */
|
|
#define RTE_ARP_OP_REVREPLY 4 /* response giving protocol address */
|
|
#define RTE_ARP_OP_INVREQUEST 8 /* request to identify peer */
|
|
#define RTE_ARP_OP_INVREPLY 9 /* response identifying peer */
|
|
|
|
struct rte_arp_ipv4 arp_data;
|
|
} __attribute__((__packed__)) __attribute__((aligned(2)));
|
|
|
|
/**
|
|
* @warning
|
|
* @b EXPERIMENTAL: this API may change without prior notice
|
|
*
|
|
* Make a RARP packet based on MAC addr.
|
|
*
|
|
* @param mpool
|
|
* Pointer to the rte_mempool
|
|
* @param mac
|
|
* Pointer to the MAC addr
|
|
*
|
|
* @return
|
|
* - RARP packet pointer on success, or NULL on error
|
|
*/
|
|
__rte_experimental
|
|
struct rte_mbuf *
|
|
rte_net_make_rarp_packet(struct rte_mempool *mpool,
|
|
const struct rte_ether_addr *mac);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* _RTE_ARP_H_ */
|