f-stack/dpdk/drivers/net/memif/memif.h

180 lines
5.0 KiB
C
Raw Normal View History

2020-06-18 16:55:50 +00:00
/* SPDX-License-Identifier: BSD-3-Clause
* Copyright 2018-2019 Cisco Systems, Inc. All rights reserved.
*/
#ifndef _MEMIF_H_
#define _MEMIF_H_
#define MEMIF_COOKIE 0x3E31F20
#define MEMIF_VERSION_MAJOR 2
#define MEMIF_VERSION_MINOR 0
#define MEMIF_VERSION ((MEMIF_VERSION_MAJOR << 8) | MEMIF_VERSION_MINOR)
#define MEMIF_NAME_SZ 32
/*
2021-02-05 08:48:47 +00:00
* C2S: direction client -> server
* S2C: direction server -> client
2020-06-18 16:55:50 +00:00
*/
/*
* Type definitions
*/
typedef enum memif_msg_type {
MEMIF_MSG_TYPE_NONE,
MEMIF_MSG_TYPE_ACK,
MEMIF_MSG_TYPE_HELLO,
MEMIF_MSG_TYPE_INIT,
MEMIF_MSG_TYPE_ADD_REGION,
MEMIF_MSG_TYPE_ADD_RING,
MEMIF_MSG_TYPE_CONNECT,
MEMIF_MSG_TYPE_CONNECTED,
MEMIF_MSG_TYPE_DISCONNECT,
} memif_msg_type_t;
typedef enum {
2021-02-05 08:48:47 +00:00
MEMIF_RING_C2S, /**< buffer ring in direction client -> server */
MEMIF_RING_S2C, /**< buffer ring in direction server -> client */
2020-06-18 16:55:50 +00:00
} memif_ring_type_t;
typedef enum {
MEMIF_INTERFACE_MODE_ETHERNET,
MEMIF_INTERFACE_MODE_IP,
MEMIF_INTERFACE_MODE_PUNT_INJECT,
} memif_interface_mode_t;
typedef uint16_t memif_region_index_t;
typedef uint32_t memif_region_offset_t;
typedef uint64_t memif_region_size_t;
typedef uint16_t memif_ring_index_t;
typedef uint32_t memif_interface_id_t;
typedef uint16_t memif_version_t;
typedef uint8_t memif_log2_ring_size_t;
/*
* Socket messages
*/
/**
2021-02-05 08:48:47 +00:00
* S2C
* Contains server interfaces configuration.
2020-06-18 16:55:50 +00:00
*/
typedef struct __rte_packed {
uint8_t name[MEMIF_NAME_SZ]; /**< Client app name. In this case DPDK version */
memif_version_t min_version; /**< lowest supported memif version */
memif_version_t max_version; /**< highest supported memif version */
memif_region_index_t max_region; /**< maximum num of regions */
2021-02-05 08:48:47 +00:00
memif_ring_index_t max_s2c_ring; /**< maximum num of S2C ring */
memif_ring_index_t max_c2s_ring; /**< maximum num of C2S rings */
2020-06-18 16:55:50 +00:00
memif_log2_ring_size_t max_log2_ring_size; /**< maximum ring size (as log2) */
} memif_msg_hello_t;
/**
2021-02-05 08:48:47 +00:00
* C2S
2020-06-18 16:55:50 +00:00
* Contains information required to identify interface
2021-02-05 08:48:47 +00:00
* to which the client wants to connect.
2020-06-18 16:55:50 +00:00
*/
typedef struct __rte_packed {
memif_version_t version; /**< memif version */
memif_interface_id_t id; /**< interface id */
memif_interface_mode_t mode:8; /**< interface mode */
uint8_t secret[24]; /**< optional security parameter */
uint8_t name[MEMIF_NAME_SZ]; /**< Client app name. In this case DPDK version */
} memif_msg_init_t;
/**
2021-02-05 08:48:47 +00:00
* C2S
* Request server to add new shared memory region to server interface.
2020-06-18 16:55:50 +00:00
* Shared files file descriptor is passed in cmsghdr.
*/
typedef struct __rte_packed {
memif_region_index_t index; /**< shm regions index */
memif_region_size_t size; /**< shm region size */
} memif_msg_add_region_t;
/**
2021-02-05 08:48:47 +00:00
* C2S
* Request server to add new ring to server interface.
2020-06-18 16:55:50 +00:00
*/
typedef struct __rte_packed {
uint16_t flags; /**< flags */
2021-02-05 08:48:47 +00:00
#define MEMIF_MSG_ADD_RING_FLAG_C2S 1 /**< ring is in C2S direction */
2020-06-18 16:55:50 +00:00
memif_ring_index_t index; /**< ring index */
memif_region_index_t region; /**< region index on which this ring is located */
memif_region_offset_t offset; /**< buffer start offset */
memif_log2_ring_size_t log2_ring_size; /**< ring size (log2) */
uint16_t private_hdr_size; /**< used for private metadata */
} memif_msg_add_ring_t;
/**
2021-02-05 08:48:47 +00:00
* C2S
2020-06-18 16:55:50 +00:00
* Finalize connection establishment.
*/
typedef struct __rte_packed {
2021-02-05 08:48:47 +00:00
uint8_t if_name[MEMIF_NAME_SZ]; /**< client interface name */
2020-06-18 16:55:50 +00:00
} memif_msg_connect_t;
/**
2021-02-05 08:48:47 +00:00
* S2C
2020-06-18 16:55:50 +00:00
* Finalize connection establishment.
*/
typedef struct __rte_packed {
2021-02-05 08:48:47 +00:00
uint8_t if_name[MEMIF_NAME_SZ]; /**< server interface name */
2020-06-18 16:55:50 +00:00
} memif_msg_connected_t;
/**
2021-02-05 08:48:47 +00:00
* C2S & S2C
2020-06-18 16:55:50 +00:00
* Disconnect interfaces.
*/
typedef struct __rte_packed {
uint32_t code; /**< error code */
uint8_t string[96]; /**< disconnect reason */
} memif_msg_disconnect_t;
typedef struct __rte_packed __rte_aligned(128)
{
memif_msg_type_t type:16;
union {
memif_msg_hello_t hello;
memif_msg_init_t init;
memif_msg_add_region_t add_region;
memif_msg_add_ring_t add_ring;
memif_msg_connect_t connect;
memif_msg_connected_t connected;
memif_msg_disconnect_t disconnect;
};
} memif_msg_t;
/*
* Ring and Descriptor Layout
*/
/**
* Buffer descriptor.
*/
typedef struct __rte_packed {
uint16_t flags; /**< flags */
#define MEMIF_DESC_FLAG_NEXT 1 /**< is chained buffer */
memif_region_index_t region; /**< region index on which the buffer is located */
uint32_t length; /**< buffer length */
memif_region_offset_t offset; /**< buffer offset */
uint32_t metadata;
} memif_desc_t;
#define MEMIF_CACHELINE_ALIGN_MARK(mark) \
2021-02-05 08:48:47 +00:00
RTE_MARKER mark __rte_cache_aligned;
2020-06-18 16:55:50 +00:00
typedef struct {
MEMIF_CACHELINE_ALIGN_MARK(cacheline0);
uint32_t cookie; /**< MEMIF_COOKIE */
uint16_t flags; /**< flags */
#define MEMIF_RING_FLAG_MASK_INT 1 /**< disable interrupt mode */
uint16_t head; /**< pointer to ring buffer head */
MEMIF_CACHELINE_ALIGN_MARK(cacheline1);
uint16_t tail; /**< pointer to ring buffer tail */
MEMIF_CACHELINE_ALIGN_MARK(cacheline2);
memif_desc_t desc[0]; /**< buffer descriptors */
} memif_ring_t;
#endif /* _MEMIF_H_ */