199a2dd95SBruce Richardson /* SPDX-License-Identifier: BSD-3-Clause 299a2dd95SBruce Richardson * Copyright(c) 2017 Intel Corporation 399a2dd95SBruce Richardson */ 499a2dd95SBruce Richardson 599a2dd95SBruce Richardson #ifndef _RTE_ETHDEV_DRIVER_H_ 699a2dd95SBruce Richardson #define _RTE_ETHDEV_DRIVER_H_ 799a2dd95SBruce Richardson 8*dbf9fc1dSBrian Dooley #ifdef __cplusplus 9*dbf9fc1dSBrian Dooley extern "C" { 10*dbf9fc1dSBrian Dooley #endif 11*dbf9fc1dSBrian Dooley 1299a2dd95SBruce Richardson /** 1399a2dd95SBruce Richardson * @file 1499a2dd95SBruce Richardson * 1599a2dd95SBruce Richardson * RTE Ethernet Device PMD API 1699a2dd95SBruce Richardson * 1799a2dd95SBruce Richardson * These APIs for the use from Ethernet drivers, user applications shouldn't 1899a2dd95SBruce Richardson * use them. 1999a2dd95SBruce Richardson * 2099a2dd95SBruce Richardson */ 2199a2dd95SBruce Richardson 2299a2dd95SBruce Richardson #include <rte_ethdev.h> 2399a2dd95SBruce Richardson 24f9bdee26SKonstantin Ananyev /** 25f9bdee26SKonstantin Ananyev * @internal 26f9bdee26SKonstantin Ananyev * Structure used to hold information about the callbacks to be called for a 2709fd4227SAndrew Rybchenko * queue on Rx and Tx. 28f9bdee26SKonstantin Ananyev */ 29f9bdee26SKonstantin Ananyev struct rte_eth_rxtx_callback { 30f9bdee26SKonstantin Ananyev struct rte_eth_rxtx_callback *next; 31f9bdee26SKonstantin Ananyev union{ 32f9bdee26SKonstantin Ananyev rte_rx_callback_fn rx; 33f9bdee26SKonstantin Ananyev rte_tx_callback_fn tx; 34f9bdee26SKonstantin Ananyev } fn; 35f9bdee26SKonstantin Ananyev void *param; 36f9bdee26SKonstantin Ananyev }; 37f9bdee26SKonstantin Ananyev 38f9bdee26SKonstantin Ananyev /** 39f9bdee26SKonstantin Ananyev * @internal 400d9f56a8SAndrew Rybchenko * The generic data structure associated with each Ethernet device. 41f9bdee26SKonstantin Ananyev * 42f9bdee26SKonstantin Ananyev * Pointers to burst-oriented packet receive and transmit functions are 43f9bdee26SKonstantin Ananyev * located at the beginning of the structure, along with the pointer to 44f9bdee26SKonstantin Ananyev * where all the data elements for the particular device are stored in shared 45f9bdee26SKonstantin Ananyev * memory. This split allows the function pointer and driver data to be per- 46f9bdee26SKonstantin Ananyev * process, while the actual configuration data for the device is shared. 47f9bdee26SKonstantin Ananyev */ 48f9bdee26SKonstantin Ananyev struct rte_eth_dev { 4955645ee6SAndrew Rybchenko eth_rx_burst_t rx_pkt_burst; /**< Pointer to PMD receive function */ 5055645ee6SAndrew Rybchenko eth_tx_burst_t tx_pkt_burst; /**< Pointer to PMD transmit function */ 51cc0a6444SAndrew Rybchenko 523c2ca0a9SAndrew Rybchenko /** Pointer to PMD transmit prepare function */ 53f9bdee26SKonstantin Ananyev eth_tx_prep_t tx_pkt_prepare; 543c2ca0a9SAndrew Rybchenko /** Get the number of used Rx descriptors */ 55f9bdee26SKonstantin Ananyev eth_rx_queue_count_t rx_queue_count; 563c2ca0a9SAndrew Rybchenko /** Check the status of a Rx descriptor */ 57f9bdee26SKonstantin Ananyev eth_rx_descriptor_status_t rx_descriptor_status; 583c2ca0a9SAndrew Rybchenko /** Check the status of a Tx descriptor */ 59f9bdee26SKonstantin Ananyev eth_tx_descriptor_status_t tx_descriptor_status; 60f9bdee26SKonstantin Ananyev 61f9bdee26SKonstantin Ananyev /** 623c2ca0a9SAndrew Rybchenko * Device data that is shared between primary and secondary processes 63f9bdee26SKonstantin Ananyev */ 64f9bdee26SKonstantin Ananyev struct rte_eth_dev_data *data; 6555645ee6SAndrew Rybchenko void *process_private; /**< Pointer to per-process device data */ 66f9bdee26SKonstantin Ananyev const struct eth_dev_ops *dev_ops; /**< Functions exported by PMD */ 67f9bdee26SKonstantin Ananyev struct rte_device *device; /**< Backing device */ 68f9bdee26SKonstantin Ananyev struct rte_intr_handle *intr_handle; /**< Device interrupt handle */ 69cc0a6444SAndrew Rybchenko 70f9bdee26SKonstantin Ananyev /** User application callbacks for NIC interrupts */ 71f9bdee26SKonstantin Ananyev struct rte_eth_dev_cb_list link_intr_cbs; 72f9bdee26SKonstantin Ananyev /** 73f9bdee26SKonstantin Ananyev * User-supplied functions called from rx_burst to post-process 74f9bdee26SKonstantin Ananyev * received packets before passing them to the user 75f9bdee26SKonstantin Ananyev */ 76f9bdee26SKonstantin Ananyev struct rte_eth_rxtx_callback *post_rx_burst_cbs[RTE_MAX_QUEUES_PER_PORT]; 77f9bdee26SKonstantin Ananyev /** 78f9bdee26SKonstantin Ananyev * User-supplied functions called from tx_burst to pre-process 7955645ee6SAndrew Rybchenko * received packets before passing them to the driver for transmission 80f9bdee26SKonstantin Ananyev */ 81f9bdee26SKonstantin Ananyev struct rte_eth_rxtx_callback *pre_tx_burst_cbs[RTE_MAX_QUEUES_PER_PORT]; 82cc0a6444SAndrew Rybchenko 83f9bdee26SKonstantin Ananyev enum rte_eth_dev_state state; /**< Flag indicating the port state */ 84f9bdee26SKonstantin Ananyev void *security_ctx; /**< Context for security ops */ 85f9bdee26SKonstantin Ananyev } __rte_cache_aligned; 86f9bdee26SKonstantin Ananyev 87f9bdee26SKonstantin Ananyev struct rte_eth_dev_sriov; 88f9bdee26SKonstantin Ananyev struct rte_eth_dev_owner; 89f9bdee26SKonstantin Ananyev 90f9bdee26SKonstantin Ananyev /** 91f9bdee26SKonstantin Ananyev * @internal 920d9f56a8SAndrew Rybchenko * The data part, with no function pointers, associated with each Ethernet 93f9bdee26SKonstantin Ananyev * device. This structure is safe to place in shared memory to be common 94f9bdee26SKonstantin Ananyev * among different processes in a multi-process configuration. 95f9bdee26SKonstantin Ananyev */ 96f9bdee26SKonstantin Ananyev struct rte_eth_dev_data { 97f9bdee26SKonstantin Ananyev char name[RTE_ETH_NAME_MAX_LEN]; /**< Unique identifier name */ 98f9bdee26SKonstantin Ananyev 9955645ee6SAndrew Rybchenko void **rx_queues; /**< Array of pointers to Rx queues */ 10055645ee6SAndrew Rybchenko void **tx_queues; /**< Array of pointers to Tx queues */ 10155645ee6SAndrew Rybchenko uint16_t nb_rx_queues; /**< Number of Rx queues */ 10255645ee6SAndrew Rybchenko uint16_t nb_tx_queues; /**< Number of Tx queues */ 103f9bdee26SKonstantin Ananyev 104f9bdee26SKonstantin Ananyev struct rte_eth_dev_sriov sriov; /**< SRIOV data */ 105f9bdee26SKonstantin Ananyev 1063c2ca0a9SAndrew Rybchenko /** PMD-specific private data. @see rte_eth_dev_release_port() */ 107f9bdee26SKonstantin Ananyev void *dev_private; 108f9bdee26SKonstantin Ananyev 10955645ee6SAndrew Rybchenko struct rte_eth_link dev_link; /**< Link-level information & status */ 11055645ee6SAndrew Rybchenko struct rte_eth_conf dev_conf; /**< Configuration applied to device */ 11155645ee6SAndrew Rybchenko uint16_t mtu; /**< Maximum Transmission Unit */ 112cc0a6444SAndrew Rybchenko 1133c2ca0a9SAndrew Rybchenko /** Common Rx buffer size handled by all queues */ 114f9bdee26SKonstantin Ananyev uint32_t min_rx_buf_size; 115f9bdee26SKonstantin Ananyev 11609fd4227SAndrew Rybchenko uint64_t rx_mbuf_alloc_failed; /**< Rx ring mbuf allocation failures */ 117cc0a6444SAndrew Rybchenko 1183c2ca0a9SAndrew Rybchenko /** Device Ethernet link address. @see rte_eth_dev_release_port() */ 119f9bdee26SKonstantin Ananyev struct rte_ether_addr *mac_addrs; 1203c2ca0a9SAndrew Rybchenko /** Bitmap associating MAC addresses to pools */ 121295968d1SFerruh Yigit uint64_t mac_pool_sel[RTE_ETH_NUM_RECEIVE_MAC_ADDR]; 1223c2ca0a9SAndrew Rybchenko /** 1233c2ca0a9SAndrew Rybchenko * Device Ethernet MAC addresses of hash filtering. 124f9bdee26SKonstantin Ananyev * @see rte_eth_dev_release_port() 125f9bdee26SKonstantin Ananyev */ 1263c2ca0a9SAndrew Rybchenko struct rte_ether_addr *hash_mac_addrs; 127cc0a6444SAndrew Rybchenko 12855645ee6SAndrew Rybchenko uint16_t port_id; /**< Device [external] port identifier */ 129f9bdee26SKonstantin Ananyev 130f9bdee26SKonstantin Ananyev __extension__ 1313c2ca0a9SAndrew Rybchenko uint8_t /** Rx promiscuous mode ON(1) / OFF(0) */ 1323c2ca0a9SAndrew Rybchenko promiscuous : 1, 1333c2ca0a9SAndrew Rybchenko /** Rx of scattered packets is ON(1) / OFF(0) */ 134f9bdee26SKonstantin Ananyev scattered_rx : 1, 1353c2ca0a9SAndrew Rybchenko /** Rx all multicast mode ON(1) / OFF(0) */ 136f9bdee26SKonstantin Ananyev all_multicast : 1, 1373c2ca0a9SAndrew Rybchenko /** Device state: STARTED(1) / STOPPED(0) */ 138f9bdee26SKonstantin Ananyev dev_started : 1, 1393c2ca0a9SAndrew Rybchenko /** Rx LRO is ON(1) / OFF(0) */ 140f9bdee26SKonstantin Ananyev lro : 1, 1413c2ca0a9SAndrew Rybchenko /** 1423c2ca0a9SAndrew Rybchenko * Indicates whether the device is configured: 1433c2ca0a9SAndrew Rybchenko * CONFIGURED(1) / NOT CONFIGURED(0) 144f9bdee26SKonstantin Ananyev */ 1453c2ca0a9SAndrew Rybchenko dev_configured : 1; 146cc0a6444SAndrew Rybchenko 1473c2ca0a9SAndrew Rybchenko /** Queues state: HAIRPIN(2) / STARTED(1) / STOPPED(0) */ 148f9bdee26SKonstantin Ananyev uint8_t rx_queue_state[RTE_MAX_QUEUES_PER_PORT]; 1493c2ca0a9SAndrew Rybchenko /** Queues state: HAIRPIN(2) / STARTED(1) / STOPPED(0) */ 150f9bdee26SKonstantin Ananyev uint8_t tx_queue_state[RTE_MAX_QUEUES_PER_PORT]; 151cc0a6444SAndrew Rybchenko 15255645ee6SAndrew Rybchenko uint32_t dev_flags; /**< Capabilities */ 15355645ee6SAndrew Rybchenko int numa_node; /**< NUMA node connection */ 154cc0a6444SAndrew Rybchenko 1553c2ca0a9SAndrew Rybchenko /** VLAN filter configuration */ 156f9bdee26SKonstantin Ananyev struct rte_vlan_filter_conf vlan_filter_conf; 157cc0a6444SAndrew Rybchenko 15855645ee6SAndrew Rybchenko struct rte_eth_dev_owner owner; /**< The port owner */ 159cc0a6444SAndrew Rybchenko 1603c2ca0a9SAndrew Rybchenko /** 1613c2ca0a9SAndrew Rybchenko * Switch-specific identifier. 162f9bdee26SKonstantin Ananyev * Valid if RTE_ETH_DEV_REPRESENTOR in dev_flags. 163f9bdee26SKonstantin Ananyev */ 1643c2ca0a9SAndrew Rybchenko uint16_t representor_id; 1653c2ca0a9SAndrew Rybchenko /** 1663c2ca0a9SAndrew Rybchenko * Port ID of the backing device. 1673c2ca0a9SAndrew Rybchenko * This device will be used to query representor info and calculate 1683c2ca0a9SAndrew Rybchenko * representor IDs. Valid if RTE_ETH_DEV_REPRESENTOR in dev_flags. 1693c2ca0a9SAndrew Rybchenko */ 170f9bdee26SKonstantin Ananyev uint16_t backer_port_id; 171f9bdee26SKonstantin Ananyev 17255645ee6SAndrew Rybchenko pthread_mutex_t flow_ops_mutex; /**< rte_flow ops mutex */ 173f9bdee26SKonstantin Ananyev } __rte_cache_aligned; 174f9bdee26SKonstantin Ananyev 175f9bdee26SKonstantin Ananyev /** 176f9bdee26SKonstantin Ananyev * @internal 177f9bdee26SKonstantin Ananyev * The pool of *rte_eth_dev* structures. The size of the pool 178f9bdee26SKonstantin Ananyev * is configured at compile-time in the <rte_ethdev.c> file. 179f9bdee26SKonstantin Ananyev */ 180f9bdee26SKonstantin Ananyev extern struct rte_eth_dev rte_eth_devices[]; 181f9bdee26SKonstantin Ananyev 1823c2ca0a9SAndrew Rybchenko /** @internal Declaration of the hairpin peer queue information structure. */ 18399a2dd95SBruce Richardson struct rte_hairpin_peer_info; 18499a2dd95SBruce Richardson 18599a2dd95SBruce Richardson /* 18699a2dd95SBruce Richardson * Definitions of all functions exported by an Ethernet driver through the 18799a2dd95SBruce Richardson * generic structure of type *eth_dev_ops* supplied in the *rte_eth_dev* 18899a2dd95SBruce Richardson * structure associated with an Ethernet device. 18999a2dd95SBruce Richardson */ 19099a2dd95SBruce Richardson 1913c2ca0a9SAndrew Rybchenko /** @internal Ethernet device configuration. */ 19299a2dd95SBruce Richardson typedef int (*eth_dev_configure_t)(struct rte_eth_dev *dev); 19399a2dd95SBruce Richardson 1943c2ca0a9SAndrew Rybchenko /** @internal Function used to start a configured Ethernet device. */ 19599a2dd95SBruce Richardson typedef int (*eth_dev_start_t)(struct rte_eth_dev *dev); 19699a2dd95SBruce Richardson 1973c2ca0a9SAndrew Rybchenko /** @internal Function used to stop a configured Ethernet device. */ 19899a2dd95SBruce Richardson typedef int (*eth_dev_stop_t)(struct rte_eth_dev *dev); 19999a2dd95SBruce Richardson 2003c2ca0a9SAndrew Rybchenko /** @internal Function used to link up a configured Ethernet device. */ 20199a2dd95SBruce Richardson typedef int (*eth_dev_set_link_up_t)(struct rte_eth_dev *dev); 20299a2dd95SBruce Richardson 2033c2ca0a9SAndrew Rybchenko /** @internal Function used to link down a configured Ethernet device. */ 20499a2dd95SBruce Richardson typedef int (*eth_dev_set_link_down_t)(struct rte_eth_dev *dev); 20599a2dd95SBruce Richardson 2063c2ca0a9SAndrew Rybchenko /** @internal Function used to close a configured Ethernet device. */ 20799a2dd95SBruce Richardson typedef int (*eth_dev_close_t)(struct rte_eth_dev *dev); 20899a2dd95SBruce Richardson 2093c2ca0a9SAndrew Rybchenko /** @internal Function used to reset a configured Ethernet device. */ 21099a2dd95SBruce Richardson typedef int (*eth_dev_reset_t)(struct rte_eth_dev *dev); 21199a2dd95SBruce Richardson 2123c2ca0a9SAndrew Rybchenko /** @internal Function used to detect an Ethernet device removal. */ 21399a2dd95SBruce Richardson typedef int (*eth_is_removed_t)(struct rte_eth_dev *dev); 21499a2dd95SBruce Richardson 21599a2dd95SBruce Richardson /** 21699a2dd95SBruce Richardson * @internal 21799a2dd95SBruce Richardson * Function used to enable the Rx promiscuous mode of an Ethernet device. 21899a2dd95SBruce Richardson * 21999a2dd95SBruce Richardson * @param dev 22099a2dd95SBruce Richardson * ethdev handle of port. 22199a2dd95SBruce Richardson * 22299a2dd95SBruce Richardson * @return 22399a2dd95SBruce Richardson * Negative errno value on error, 0 on success. 22499a2dd95SBruce Richardson * 22599a2dd95SBruce Richardson * @retval 0 22699a2dd95SBruce Richardson * Success, promiscuous mode is enabled. 22799a2dd95SBruce Richardson * @retval -ENOTSUP 22899a2dd95SBruce Richardson * Promiscuous mode is not supported. 22999a2dd95SBruce Richardson * @retval -ENODEV 23099a2dd95SBruce Richardson * Device is gone. 23199a2dd95SBruce Richardson * @retval -E_RTE_SECONDARY 23299a2dd95SBruce Richardson * Function was called from a secondary process instance and not supported. 23399a2dd95SBruce Richardson * @retval -ETIMEDOUT 23451395027SFerruh Yigit * Attempt to enable promiscuous mode failed because of timeout. 23599a2dd95SBruce Richardson * @retval -EAGAIN 23699a2dd95SBruce Richardson * Failed to enable promiscuous mode. 23799a2dd95SBruce Richardson */ 23899a2dd95SBruce Richardson typedef int (*eth_promiscuous_enable_t)(struct rte_eth_dev *dev); 23999a2dd95SBruce Richardson 24099a2dd95SBruce Richardson /** 24199a2dd95SBruce Richardson * @internal 24299a2dd95SBruce Richardson * Function used to disable the Rx promiscuous mode of an Ethernet device. 24399a2dd95SBruce Richardson * 24499a2dd95SBruce Richardson * @param dev 24599a2dd95SBruce Richardson * ethdev handle of port. 24699a2dd95SBruce Richardson * 24799a2dd95SBruce Richardson * @return 24899a2dd95SBruce Richardson * Negative errno value on error, 0 on success. 24999a2dd95SBruce Richardson * 25099a2dd95SBruce Richardson * @retval 0 25199a2dd95SBruce Richardson * Success, promiscuous mode is disabled. 25299a2dd95SBruce Richardson * @retval -ENOTSUP 25399a2dd95SBruce Richardson * Promiscuous mode disabling is not supported. 25499a2dd95SBruce Richardson * @retval -ENODEV 25599a2dd95SBruce Richardson * Device is gone. 25699a2dd95SBruce Richardson * @retval -E_RTE_SECONDARY 25799a2dd95SBruce Richardson * Function was called from a secondary process instance and not supported. 25899a2dd95SBruce Richardson * @retval -ETIMEDOUT 25951395027SFerruh Yigit * Attempt to disable promiscuous mode failed because of timeout. 26099a2dd95SBruce Richardson * @retval -EAGAIN 26199a2dd95SBruce Richardson * Failed to disable promiscuous mode. 26299a2dd95SBruce Richardson */ 26399a2dd95SBruce Richardson typedef int (*eth_promiscuous_disable_t)(struct rte_eth_dev *dev); 26499a2dd95SBruce Richardson 26599a2dd95SBruce Richardson /** 26699a2dd95SBruce Richardson * @internal 26799a2dd95SBruce Richardson * Enable the receipt of all multicast packets by an Ethernet device. 26899a2dd95SBruce Richardson * 26999a2dd95SBruce Richardson * @param dev 27099a2dd95SBruce Richardson * ethdev handle of port. 27199a2dd95SBruce Richardson * 27299a2dd95SBruce Richardson * @return 27399a2dd95SBruce Richardson * Negative errno value on error, 0 on success. 27499a2dd95SBruce Richardson * 27599a2dd95SBruce Richardson * @retval 0 27699a2dd95SBruce Richardson * Success, all-multicast mode is enabled. 27799a2dd95SBruce Richardson * @retval -ENOTSUP 27899a2dd95SBruce Richardson * All-multicast mode is not supported. 27999a2dd95SBruce Richardson * @retval -ENODEV 28099a2dd95SBruce Richardson * Device is gone. 28199a2dd95SBruce Richardson * @retval -E_RTE_SECONDARY 28299a2dd95SBruce Richardson * Function was called from a secondary process instance and not supported. 28399a2dd95SBruce Richardson * @retval -ETIMEDOUT 28499a2dd95SBruce Richardson * Attempt to enable all-multicast mode failed because of timeout. 28599a2dd95SBruce Richardson * @retval -EAGAIN 28699a2dd95SBruce Richardson * Failed to enable all-multicast mode. 28799a2dd95SBruce Richardson */ 28899a2dd95SBruce Richardson typedef int (*eth_allmulticast_enable_t)(struct rte_eth_dev *dev); 28999a2dd95SBruce Richardson 29099a2dd95SBruce Richardson /** 29199a2dd95SBruce Richardson * @internal 29299a2dd95SBruce Richardson * Disable the receipt of all multicast packets by an Ethernet device. 29399a2dd95SBruce Richardson * 29499a2dd95SBruce Richardson * @param dev 29599a2dd95SBruce Richardson * ethdev handle of port. 29699a2dd95SBruce Richardson * 29799a2dd95SBruce Richardson * @return 29899a2dd95SBruce Richardson * Negative errno value on error, 0 on success. 29999a2dd95SBruce Richardson * 30099a2dd95SBruce Richardson * @retval 0 30199a2dd95SBruce Richardson * Success, all-multicast mode is disabled. 30299a2dd95SBruce Richardson * @retval -ENOTSUP 30399a2dd95SBruce Richardson * All-multicast mode disabling is not supported. 30499a2dd95SBruce Richardson * @retval -ENODEV 30599a2dd95SBruce Richardson * Device is gone. 30699a2dd95SBruce Richardson * @retval -E_RTE_SECONDARY 30799a2dd95SBruce Richardson * Function was called from a secondary process instance and not supported. 30899a2dd95SBruce Richardson * @retval -ETIMEDOUT 30999a2dd95SBruce Richardson * Attempt to disable all-multicast mode failed because of timeout. 31099a2dd95SBruce Richardson * @retval -EAGAIN 31199a2dd95SBruce Richardson * Failed to disable all-multicast mode. 31299a2dd95SBruce Richardson */ 31399a2dd95SBruce Richardson typedef int (*eth_allmulticast_disable_t)(struct rte_eth_dev *dev); 31499a2dd95SBruce Richardson 3153c2ca0a9SAndrew Rybchenko /** 3163c2ca0a9SAndrew Rybchenko * @internal 3173c2ca0a9SAndrew Rybchenko * Get link speed, duplex mode and state (up/down) of an Ethernet device. 3183c2ca0a9SAndrew Rybchenko */ 31999a2dd95SBruce Richardson typedef int (*eth_link_update_t)(struct rte_eth_dev *dev, 32099a2dd95SBruce Richardson int wait_to_complete); 32199a2dd95SBruce Richardson 3223c2ca0a9SAndrew Rybchenko /** @internal Get global I/O statistics of an Ethernet device. */ 32399a2dd95SBruce Richardson typedef int (*eth_stats_get_t)(struct rte_eth_dev *dev, 32499a2dd95SBruce Richardson struct rte_eth_stats *igb_stats); 32599a2dd95SBruce Richardson 32699a2dd95SBruce Richardson /** 32799a2dd95SBruce Richardson * @internal 32899a2dd95SBruce Richardson * Reset global I/O statistics of an Ethernet device to 0. 32999a2dd95SBruce Richardson * 33099a2dd95SBruce Richardson * @param dev 33199a2dd95SBruce Richardson * ethdev handle of port. 33299a2dd95SBruce Richardson * 33399a2dd95SBruce Richardson * @return 33499a2dd95SBruce Richardson * Negative errno value on error, 0 on success. 33599a2dd95SBruce Richardson * 33699a2dd95SBruce Richardson * @retval 0 33799a2dd95SBruce Richardson * Success, statistics has been reset. 33899a2dd95SBruce Richardson * @retval -ENOTSUP 33999a2dd95SBruce Richardson * Resetting statistics is not supported. 34099a2dd95SBruce Richardson * @retval -EINVAL 34199a2dd95SBruce Richardson * Resetting statistics is not valid. 34299a2dd95SBruce Richardson * @retval -ENOMEM 34399a2dd95SBruce Richardson * Not enough memory to get the stats. 34499a2dd95SBruce Richardson */ 34599a2dd95SBruce Richardson typedef int (*eth_stats_reset_t)(struct rte_eth_dev *dev); 34699a2dd95SBruce Richardson 3473c2ca0a9SAndrew Rybchenko /** @internal Get extended stats of an Ethernet device. */ 34899a2dd95SBruce Richardson typedef int (*eth_xstats_get_t)(struct rte_eth_dev *dev, 34999a2dd95SBruce Richardson struct rte_eth_xstat *stats, unsigned int n); 35099a2dd95SBruce Richardson 35171b5e430SIvan Ilchenko /** 35271b5e430SIvan Ilchenko * @internal 35371b5e430SIvan Ilchenko * Get extended stats of an Ethernet device. 35471b5e430SIvan Ilchenko * 35571b5e430SIvan Ilchenko * @param dev 35671b5e430SIvan Ilchenko * ethdev handle of port. 35771b5e430SIvan Ilchenko * @param ids 35871b5e430SIvan Ilchenko * IDs array to retrieve specific statistics. Must not be NULL. 35971b5e430SIvan Ilchenko * @param values 36071b5e430SIvan Ilchenko * A pointer to a table to be filled with device statistics values. 36171b5e430SIvan Ilchenko * Must not be NULL. 36271b5e430SIvan Ilchenko * @param n 36371b5e430SIvan Ilchenko * Element count in @p ids and @p values. 36471b5e430SIvan Ilchenko * 36571b5e430SIvan Ilchenko * @return 36671b5e430SIvan Ilchenko * - A number of filled in stats. 36771b5e430SIvan Ilchenko * - A negative value on error. 36871b5e430SIvan Ilchenko */ 36999a2dd95SBruce Richardson typedef int (*eth_xstats_get_by_id_t)(struct rte_eth_dev *dev, 37099a2dd95SBruce Richardson const uint64_t *ids, 37199a2dd95SBruce Richardson uint64_t *values, 37299a2dd95SBruce Richardson unsigned int n); 37399a2dd95SBruce Richardson 37499a2dd95SBruce Richardson /** 37599a2dd95SBruce Richardson * @internal 37699a2dd95SBruce Richardson * Reset extended stats of an Ethernet device. 37799a2dd95SBruce Richardson * 37899a2dd95SBruce Richardson * @param dev 37999a2dd95SBruce Richardson * ethdev handle of port. 38099a2dd95SBruce Richardson * 38199a2dd95SBruce Richardson * @return 38299a2dd95SBruce Richardson * Negative errno value on error, 0 on success. 38399a2dd95SBruce Richardson * 38499a2dd95SBruce Richardson * @retval 0 38599a2dd95SBruce Richardson * Success, statistics has been reset. 38699a2dd95SBruce Richardson * @retval -ENOTSUP 38799a2dd95SBruce Richardson * Resetting statistics is not supported. 38899a2dd95SBruce Richardson * @retval -EINVAL 38999a2dd95SBruce Richardson * Resetting statistics is not valid. 39099a2dd95SBruce Richardson * @retval -ENOMEM 39199a2dd95SBruce Richardson * Not enough memory to get the stats. 39299a2dd95SBruce Richardson */ 39399a2dd95SBruce Richardson typedef int (*eth_xstats_reset_t)(struct rte_eth_dev *dev); 39499a2dd95SBruce Richardson 3953c2ca0a9SAndrew Rybchenko /** @internal Get names of extended stats of an Ethernet device. */ 39699a2dd95SBruce Richardson typedef int (*eth_xstats_get_names_t)(struct rte_eth_dev *dev, 39799a2dd95SBruce Richardson struct rte_eth_xstat_name *xstats_names, unsigned int size); 39899a2dd95SBruce Richardson 39971b5e430SIvan Ilchenko /** 40071b5e430SIvan Ilchenko * @internal 40171b5e430SIvan Ilchenko * Get names of extended stats of an Ethernet device. 40271b5e430SIvan Ilchenko * 40371b5e430SIvan Ilchenko * @param dev 40471b5e430SIvan Ilchenko * ethdev handle of port. 4058c9f976fSAndrew Rybchenko * @param ids 4068c9f976fSAndrew Rybchenko * IDs array to retrieve specific statistics. Must not be NULL. 40771b5e430SIvan Ilchenko * @param xstats_names 40871b5e430SIvan Ilchenko * An rte_eth_xstat_name array of at least @p size elements to be filled. 40971b5e430SIvan Ilchenko * Must not be NULL. 41071b5e430SIvan Ilchenko * @param size 41171b5e430SIvan Ilchenko * Element count in @p ids and @p xstats_names. 41271b5e430SIvan Ilchenko * 41371b5e430SIvan Ilchenko * @return 41471b5e430SIvan Ilchenko * - A number of filled in stats. 41571b5e430SIvan Ilchenko * - A negative value on error. 41671b5e430SIvan Ilchenko */ 41799a2dd95SBruce Richardson typedef int (*eth_xstats_get_names_by_id_t)(struct rte_eth_dev *dev, 4188c9f976fSAndrew Rybchenko const uint64_t *ids, struct rte_eth_xstat_name *xstats_names, 41999a2dd95SBruce Richardson unsigned int size); 42099a2dd95SBruce Richardson 4213c2ca0a9SAndrew Rybchenko /** 4223c2ca0a9SAndrew Rybchenko * @internal 4233c2ca0a9SAndrew Rybchenko * Set a queue statistics mapping for a Tx/Rx queue of an Ethernet device. 4243c2ca0a9SAndrew Rybchenko */ 42599a2dd95SBruce Richardson typedef int (*eth_queue_stats_mapping_set_t)(struct rte_eth_dev *dev, 42699a2dd95SBruce Richardson uint16_t queue_id, 42799a2dd95SBruce Richardson uint8_t stat_idx, 42899a2dd95SBruce Richardson uint8_t is_rx); 42999a2dd95SBruce Richardson 4303c2ca0a9SAndrew Rybchenko /** @internal Get specific information of an Ethernet device. */ 43199a2dd95SBruce Richardson typedef int (*eth_dev_infos_get_t)(struct rte_eth_dev *dev, 43299a2dd95SBruce Richardson struct rte_eth_dev_info *dev_info); 43399a2dd95SBruce Richardson 4343c2ca0a9SAndrew Rybchenko /** @internal Get supported ptypes of an Ethernet device. */ 43599a2dd95SBruce Richardson typedef const uint32_t *(*eth_dev_supported_ptypes_get_t)(struct rte_eth_dev *dev); 43699a2dd95SBruce Richardson 43799a2dd95SBruce Richardson /** 43899a2dd95SBruce Richardson * @internal 43999a2dd95SBruce Richardson * Inform Ethernet device about reduced range of packet types to handle. 44099a2dd95SBruce Richardson * 44199a2dd95SBruce Richardson * @param dev 44299a2dd95SBruce Richardson * The Ethernet device identifier. 44399a2dd95SBruce Richardson * @param ptype_mask 44499a2dd95SBruce Richardson * The ptype family that application is interested in should be bitwise OR of 44599a2dd95SBruce Richardson * RTE_PTYPE_*_MASK or 0. 44699a2dd95SBruce Richardson * @return 44799a2dd95SBruce Richardson * - (0) if Success. 44899a2dd95SBruce Richardson */ 44999a2dd95SBruce Richardson typedef int (*eth_dev_ptypes_set_t)(struct rte_eth_dev *dev, 45099a2dd95SBruce Richardson uint32_t ptype_mask); 45199a2dd95SBruce Richardson 4523c2ca0a9SAndrew Rybchenko /** @internal Start Rx and Tx of a queue of an Ethernet device. */ 45399a2dd95SBruce Richardson typedef int (*eth_queue_start_t)(struct rte_eth_dev *dev, 45499a2dd95SBruce Richardson uint16_t queue_id); 45599a2dd95SBruce Richardson 4563c2ca0a9SAndrew Rybchenko /** @internal Stop Rx and Tx of a queue of an Ethernet device. */ 45799a2dd95SBruce Richardson typedef int (*eth_queue_stop_t)(struct rte_eth_dev *dev, 45899a2dd95SBruce Richardson uint16_t queue_id); 45999a2dd95SBruce Richardson 4603c2ca0a9SAndrew Rybchenko /** @internal Set up a receive queue of an Ethernet device. */ 46199a2dd95SBruce Richardson typedef int (*eth_rx_queue_setup_t)(struct rte_eth_dev *dev, 46299a2dd95SBruce Richardson uint16_t rx_queue_id, 46399a2dd95SBruce Richardson uint16_t nb_rx_desc, 46499a2dd95SBruce Richardson unsigned int socket_id, 46599a2dd95SBruce Richardson const struct rte_eth_rxconf *rx_conf, 46699a2dd95SBruce Richardson struct rte_mempool *mb_pool); 46799a2dd95SBruce Richardson 4683c2ca0a9SAndrew Rybchenko /** @internal Setup a transmit queue of an Ethernet device. */ 46999a2dd95SBruce Richardson typedef int (*eth_tx_queue_setup_t)(struct rte_eth_dev *dev, 47099a2dd95SBruce Richardson uint16_t tx_queue_id, 47199a2dd95SBruce Richardson uint16_t nb_tx_desc, 47299a2dd95SBruce Richardson unsigned int socket_id, 47399a2dd95SBruce Richardson const struct rte_eth_txconf *tx_conf); 47499a2dd95SBruce Richardson 4753c2ca0a9SAndrew Rybchenko /** @internal Enable interrupt of a receive queue of an Ethernet device. */ 47699a2dd95SBruce Richardson typedef int (*eth_rx_enable_intr_t)(struct rte_eth_dev *dev, 47799a2dd95SBruce Richardson uint16_t rx_queue_id); 47899a2dd95SBruce Richardson 4793c2ca0a9SAndrew Rybchenko /** @internal Disable interrupt of a receive queue of an Ethernet device. */ 48099a2dd95SBruce Richardson typedef int (*eth_rx_disable_intr_t)(struct rte_eth_dev *dev, 48199a2dd95SBruce Richardson uint16_t rx_queue_id); 48299a2dd95SBruce Richardson 4833c2ca0a9SAndrew Rybchenko /** @internal Release memory resources allocated by given Rx/Tx queue. */ 4847483341aSXueming Li typedef void (*eth_queue_release_t)(struct rte_eth_dev *dev, 4857483341aSXueming Li uint16_t queue_id); 48699a2dd95SBruce Richardson 4873c2ca0a9SAndrew Rybchenko /** @internal Get firmware information of an Ethernet device. */ 48899a2dd95SBruce Richardson typedef int (*eth_fw_version_get_t)(struct rte_eth_dev *dev, 48999a2dd95SBruce Richardson char *fw_version, size_t fw_size); 49099a2dd95SBruce Richardson 4913c2ca0a9SAndrew Rybchenko /** @internal Force mbufs to be from Tx ring. */ 49299a2dd95SBruce Richardson typedef int (*eth_tx_done_cleanup_t)(void *txq, uint32_t free_cnt); 49399a2dd95SBruce Richardson 49499a2dd95SBruce Richardson typedef void (*eth_rxq_info_get_t)(struct rte_eth_dev *dev, 49599a2dd95SBruce Richardson uint16_t rx_queue_id, struct rte_eth_rxq_info *qinfo); 49699a2dd95SBruce Richardson 49799a2dd95SBruce Richardson typedef void (*eth_txq_info_get_t)(struct rte_eth_dev *dev, 49899a2dd95SBruce Richardson uint16_t tx_queue_id, struct rte_eth_txq_info *qinfo); 49999a2dd95SBruce Richardson 50099a2dd95SBruce Richardson typedef int (*eth_burst_mode_get_t)(struct rte_eth_dev *dev, 50199a2dd95SBruce Richardson uint16_t queue_id, struct rte_eth_burst_mode *mode); 50299a2dd95SBruce Richardson 5033c2ca0a9SAndrew Rybchenko /** @internal Set MTU. */ 50499a2dd95SBruce Richardson typedef int (*mtu_set_t)(struct rte_eth_dev *dev, uint16_t mtu); 50599a2dd95SBruce Richardson 5063c2ca0a9SAndrew Rybchenko /** @internal Filtering of a VLAN Tag Identifier by an Ethernet device. */ 50799a2dd95SBruce Richardson typedef int (*vlan_filter_set_t)(struct rte_eth_dev *dev, 50899a2dd95SBruce Richardson uint16_t vlan_id, 50999a2dd95SBruce Richardson int on); 51099a2dd95SBruce Richardson 5113c2ca0a9SAndrew Rybchenko /** @internal Set the outer/inner VLAN-TPID by an Ethernet device. */ 51299a2dd95SBruce Richardson typedef int (*vlan_tpid_set_t)(struct rte_eth_dev *dev, 51399a2dd95SBruce Richardson enum rte_vlan_type type, uint16_t tpid); 51499a2dd95SBruce Richardson 5153c2ca0a9SAndrew Rybchenko /** @internal Set VLAN offload function by an Ethernet device. */ 51699a2dd95SBruce Richardson typedef int (*vlan_offload_set_t)(struct rte_eth_dev *dev, int mask); 51799a2dd95SBruce Richardson 5183c2ca0a9SAndrew Rybchenko /** @internal Set port based Tx VLAN insertion by an Ethernet device. */ 51999a2dd95SBruce Richardson typedef int (*vlan_pvid_set_t)(struct rte_eth_dev *dev, 52099a2dd95SBruce Richardson uint16_t vlan_id, 52199a2dd95SBruce Richardson int on); 52299a2dd95SBruce Richardson 5233c2ca0a9SAndrew Rybchenko /** @internal VLAN stripping enable/disable by an queue of Ethernet device. */ 52499a2dd95SBruce Richardson typedef void (*vlan_strip_queue_set_t)(struct rte_eth_dev *dev, 52599a2dd95SBruce Richardson uint16_t rx_queue_id, 52699a2dd95SBruce Richardson int on); 52799a2dd95SBruce Richardson 5283c2ca0a9SAndrew Rybchenko /** @internal Get current flow control parameter on an Ethernet device. */ 52999a2dd95SBruce Richardson typedef int (*flow_ctrl_get_t)(struct rte_eth_dev *dev, 53099a2dd95SBruce Richardson struct rte_eth_fc_conf *fc_conf); 53199a2dd95SBruce Richardson 5323c2ca0a9SAndrew Rybchenko /** @internal Setup flow control parameter on an Ethernet device. */ 53399a2dd95SBruce Richardson typedef int (*flow_ctrl_set_t)(struct rte_eth_dev *dev, 53499a2dd95SBruce Richardson struct rte_eth_fc_conf *fc_conf); 53599a2dd95SBruce Richardson 5363c2ca0a9SAndrew Rybchenko /** @internal Setup priority flow control parameter on an Ethernet device. */ 53799a2dd95SBruce Richardson typedef int (*priority_flow_ctrl_set_t)(struct rte_eth_dev *dev, 53899a2dd95SBruce Richardson struct rte_eth_pfc_conf *pfc_conf); 53999a2dd95SBruce Richardson 5400de345e9SJerin Jacob /** @internal Get info for queue based PFC on an Ethernet device. */ 5410de345e9SJerin Jacob typedef int (*priority_flow_ctrl_queue_info_get_t)(struct rte_eth_dev *dev, 5420de345e9SJerin Jacob struct rte_eth_pfc_queue_info *pfc_queue_info); 5430de345e9SJerin Jacob /** @internal Configure queue based PFC parameter on an Ethernet device. */ 5440de345e9SJerin Jacob typedef int (*priority_flow_ctrl_queue_config_t)(struct rte_eth_dev *dev, 5450de345e9SJerin Jacob struct rte_eth_pfc_queue_conf *pfc_queue_conf); 5460de345e9SJerin Jacob 5473c2ca0a9SAndrew Rybchenko /** @internal Update RSS redirection table on an Ethernet device. */ 54899a2dd95SBruce Richardson typedef int (*reta_update_t)(struct rte_eth_dev *dev, 54999a2dd95SBruce Richardson struct rte_eth_rss_reta_entry64 *reta_conf, 55099a2dd95SBruce Richardson uint16_t reta_size); 55199a2dd95SBruce Richardson 5523c2ca0a9SAndrew Rybchenko /** @internal Query RSS redirection table on an Ethernet device. */ 55399a2dd95SBruce Richardson typedef int (*reta_query_t)(struct rte_eth_dev *dev, 55499a2dd95SBruce Richardson struct rte_eth_rss_reta_entry64 *reta_conf, 55599a2dd95SBruce Richardson uint16_t reta_size); 55699a2dd95SBruce Richardson 5573c2ca0a9SAndrew Rybchenko /** @internal Update RSS hash configuration of an Ethernet device. */ 55899a2dd95SBruce Richardson typedef int (*rss_hash_update_t)(struct rte_eth_dev *dev, 55999a2dd95SBruce Richardson struct rte_eth_rss_conf *rss_conf); 56099a2dd95SBruce Richardson 5613c2ca0a9SAndrew Rybchenko /** @internal Get current RSS hash configuration of an Ethernet device. */ 56299a2dd95SBruce Richardson typedef int (*rss_hash_conf_get_t)(struct rte_eth_dev *dev, 56399a2dd95SBruce Richardson struct rte_eth_rss_conf *rss_conf); 56499a2dd95SBruce Richardson 5653c2ca0a9SAndrew Rybchenko /** @internal Turn on SW controllable LED on an Ethernet device. */ 56699a2dd95SBruce Richardson typedef int (*eth_dev_led_on_t)(struct rte_eth_dev *dev); 56799a2dd95SBruce Richardson 5683c2ca0a9SAndrew Rybchenko /** @internal Turn off SW controllable LED on an Ethernet device. */ 56999a2dd95SBruce Richardson typedef int (*eth_dev_led_off_t)(struct rte_eth_dev *dev); 57099a2dd95SBruce Richardson 5713c2ca0a9SAndrew Rybchenko /** @internal Remove MAC address from receive address register. */ 57299a2dd95SBruce Richardson typedef void (*eth_mac_addr_remove_t)(struct rte_eth_dev *dev, uint32_t index); 57399a2dd95SBruce Richardson 5743c2ca0a9SAndrew Rybchenko /** @internal Set a MAC address into Receive Address Register. */ 57599a2dd95SBruce Richardson typedef int (*eth_mac_addr_add_t)(struct rte_eth_dev *dev, 57699a2dd95SBruce Richardson struct rte_ether_addr *mac_addr, 57799a2dd95SBruce Richardson uint32_t index, 57899a2dd95SBruce Richardson uint32_t vmdq); 57999a2dd95SBruce Richardson 5803c2ca0a9SAndrew Rybchenko /** @internal Set a MAC address into Receive Address Register. */ 58199a2dd95SBruce Richardson typedef int (*eth_mac_addr_set_t)(struct rte_eth_dev *dev, 58299a2dd95SBruce Richardson struct rte_ether_addr *mac_addr); 58399a2dd95SBruce Richardson 5843c2ca0a9SAndrew Rybchenko /** @internal Set a Unicast Hash bitmap. */ 58599a2dd95SBruce Richardson typedef int (*eth_uc_hash_table_set_t)(struct rte_eth_dev *dev, 58699a2dd95SBruce Richardson struct rte_ether_addr *mac_addr, 58799a2dd95SBruce Richardson uint8_t on); 58899a2dd95SBruce Richardson 5893c2ca0a9SAndrew Rybchenko /** @internal Set all Unicast Hash bitmap. */ 59099a2dd95SBruce Richardson typedef int (*eth_uc_all_hash_table_set_t)(struct rte_eth_dev *dev, 59199a2dd95SBruce Richardson uint8_t on); 59299a2dd95SBruce Richardson 5933c2ca0a9SAndrew Rybchenko /** @internal Set queue Tx rate. */ 59499a2dd95SBruce Richardson typedef int (*eth_set_queue_rate_limit_t)(struct rte_eth_dev *dev, 59599a2dd95SBruce Richardson uint16_t queue_idx, 59699a2dd95SBruce Richardson uint16_t tx_rate); 59799a2dd95SBruce Richardson 5983c2ca0a9SAndrew Rybchenko /** @internal Add tunneling UDP port. */ 59999a2dd95SBruce Richardson typedef int (*eth_udp_tunnel_port_add_t)(struct rte_eth_dev *dev, 60099a2dd95SBruce Richardson struct rte_eth_udp_tunnel *tunnel_udp); 60199a2dd95SBruce Richardson 6023c2ca0a9SAndrew Rybchenko /** @internal Delete tunneling UDP port. */ 60399a2dd95SBruce Richardson typedef int (*eth_udp_tunnel_port_del_t)(struct rte_eth_dev *dev, 60499a2dd95SBruce Richardson struct rte_eth_udp_tunnel *tunnel_udp); 60599a2dd95SBruce Richardson 6063c2ca0a9SAndrew Rybchenko /** @internal set the list of multicast addresses on an Ethernet device. */ 60799a2dd95SBruce Richardson typedef int (*eth_set_mc_addr_list_t)(struct rte_eth_dev *dev, 60899a2dd95SBruce Richardson struct rte_ether_addr *mc_addr_set, 60999a2dd95SBruce Richardson uint32_t nb_mc_addr); 61099a2dd95SBruce Richardson 6113c2ca0a9SAndrew Rybchenko /** @internal Function used to enable IEEE1588/802.1AS timestamping. */ 61299a2dd95SBruce Richardson typedef int (*eth_timesync_enable_t)(struct rte_eth_dev *dev); 61399a2dd95SBruce Richardson 6143c2ca0a9SAndrew Rybchenko /** @internal Function used to disable IEEE1588/802.1AS timestamping. */ 61599a2dd95SBruce Richardson typedef int (*eth_timesync_disable_t)(struct rte_eth_dev *dev); 61699a2dd95SBruce Richardson 6173c2ca0a9SAndrew Rybchenko /** @internal Function used to read an Rx IEEE1588/802.1AS timestamp. */ 61899a2dd95SBruce Richardson typedef int (*eth_timesync_read_rx_timestamp_t)(struct rte_eth_dev *dev, 61999a2dd95SBruce Richardson struct timespec *timestamp, 62099a2dd95SBruce Richardson uint32_t flags); 62199a2dd95SBruce Richardson 6223c2ca0a9SAndrew Rybchenko /** @internal Function used to read a Tx IEEE1588/802.1AS timestamp. */ 62399a2dd95SBruce Richardson typedef int (*eth_timesync_read_tx_timestamp_t)(struct rte_eth_dev *dev, 62499a2dd95SBruce Richardson struct timespec *timestamp); 62599a2dd95SBruce Richardson 6263c2ca0a9SAndrew Rybchenko /** @internal Function used to adjust the device clock. */ 62799a2dd95SBruce Richardson typedef int (*eth_timesync_adjust_time)(struct rte_eth_dev *dev, int64_t); 62899a2dd95SBruce Richardson 6293c2ca0a9SAndrew Rybchenko /** @internal Function used to get time from the device clock. */ 63099a2dd95SBruce Richardson typedef int (*eth_timesync_read_time)(struct rte_eth_dev *dev, 63199a2dd95SBruce Richardson struct timespec *timestamp); 63299a2dd95SBruce Richardson 6333c2ca0a9SAndrew Rybchenko /** @internal Function used to get time from the device clock. */ 63499a2dd95SBruce Richardson typedef int (*eth_timesync_write_time)(struct rte_eth_dev *dev, 63599a2dd95SBruce Richardson const struct timespec *timestamp); 63699a2dd95SBruce Richardson 6373c2ca0a9SAndrew Rybchenko /** @internal Function used to get the current value of the device clock. */ 63899a2dd95SBruce Richardson typedef int (*eth_read_clock)(struct rte_eth_dev *dev, 63999a2dd95SBruce Richardson uint64_t *timestamp); 64099a2dd95SBruce Richardson 6413c2ca0a9SAndrew Rybchenko /** @internal Retrieve registers. */ 64299a2dd95SBruce Richardson typedef int (*eth_get_reg_t)(struct rte_eth_dev *dev, 64399a2dd95SBruce Richardson struct rte_dev_reg_info *info); 64499a2dd95SBruce Richardson 645bf73419dSAndrew Rybchenko /** @internal Retrieve EEPROM size. */ 64699a2dd95SBruce Richardson typedef int (*eth_get_eeprom_length_t)(struct rte_eth_dev *dev); 64799a2dd95SBruce Richardson 648bf73419dSAndrew Rybchenko /** @internal Retrieve EEPROM data. */ 64999a2dd95SBruce Richardson typedef int (*eth_get_eeprom_t)(struct rte_eth_dev *dev, 65099a2dd95SBruce Richardson struct rte_dev_eeprom_info *info); 65199a2dd95SBruce Richardson 652bf73419dSAndrew Rybchenko /** @internal Program EEPROM data. */ 65399a2dd95SBruce Richardson typedef int (*eth_set_eeprom_t)(struct rte_eth_dev *dev, 65499a2dd95SBruce Richardson struct rte_dev_eeprom_info *info); 65599a2dd95SBruce Richardson 656bf73419dSAndrew Rybchenko /** @internal Retrieve type and size of plugin module EEPROM. */ 65799a2dd95SBruce Richardson typedef int (*eth_get_module_info_t)(struct rte_eth_dev *dev, 65899a2dd95SBruce Richardson struct rte_eth_dev_module_info *modinfo); 65999a2dd95SBruce Richardson 660bf73419dSAndrew Rybchenko /** @internal Retrieve plugin module EEPROM data. */ 66199a2dd95SBruce Richardson typedef int (*eth_get_module_eeprom_t)(struct rte_eth_dev *dev, 66299a2dd95SBruce Richardson struct rte_dev_eeprom_info *info); 66399a2dd95SBruce Richardson 66499a2dd95SBruce Richardson struct rte_flow_ops; 66599a2dd95SBruce Richardson /** 66699a2dd95SBruce Richardson * @internal 66799a2dd95SBruce Richardson * Get flow operations. 66899a2dd95SBruce Richardson * 66999a2dd95SBruce Richardson * If the flow API is not supported for the specified device, 67099a2dd95SBruce Richardson * the driver can return NULL. 67199a2dd95SBruce Richardson */ 67299a2dd95SBruce Richardson typedef int (*eth_flow_ops_get_t)(struct rte_eth_dev *dev, 67399a2dd95SBruce Richardson const struct rte_flow_ops **ops); 67499a2dd95SBruce Richardson 6753c2ca0a9SAndrew Rybchenko /** @internal Get Traffic Management (TM) operations on an Ethernet device. */ 67699a2dd95SBruce Richardson typedef int (*eth_tm_ops_get_t)(struct rte_eth_dev *dev, void *ops); 67799a2dd95SBruce Richardson 6783c2ca0a9SAndrew Rybchenko /** @internal Get Traffic Metering and Policing (MTR) operations. */ 67999a2dd95SBruce Richardson typedef int (*eth_mtr_ops_get_t)(struct rte_eth_dev *dev, void *ops); 68099a2dd95SBruce Richardson 681064e90c4SAndrew Rybchenko /** @internal Get DCB information on an Ethernet device. */ 68299a2dd95SBruce Richardson typedef int (*eth_get_dcb_info)(struct rte_eth_dev *dev, 68399a2dd95SBruce Richardson struct rte_eth_dcb_info *dcb_info); 68499a2dd95SBruce Richardson 6853c2ca0a9SAndrew Rybchenko /** @internal Test if a port supports specific mempool ops. */ 68699a2dd95SBruce Richardson typedef int (*eth_pool_ops_supported_t)(struct rte_eth_dev *dev, 68799a2dd95SBruce Richardson const char *pool); 68899a2dd95SBruce Richardson 68999a2dd95SBruce Richardson /** 69099a2dd95SBruce Richardson * @internal 69199a2dd95SBruce Richardson * Get the hairpin capabilities. 69299a2dd95SBruce Richardson * 69399a2dd95SBruce Richardson * @param dev 69499a2dd95SBruce Richardson * ethdev handle of port. 69599a2dd95SBruce Richardson * @param cap 69699a2dd95SBruce Richardson * returns the hairpin capabilities from the device. 69799a2dd95SBruce Richardson * 69899a2dd95SBruce Richardson * @return 69999a2dd95SBruce Richardson * Negative errno value on error, 0 on success. 70099a2dd95SBruce Richardson * 70199a2dd95SBruce Richardson * @retval 0 70299a2dd95SBruce Richardson * Success, hairpin is supported. 70399a2dd95SBruce Richardson * @retval -ENOTSUP 70499a2dd95SBruce Richardson * Hairpin is not supported. 70599a2dd95SBruce Richardson */ 70699a2dd95SBruce Richardson typedef int (*eth_hairpin_cap_get_t)(struct rte_eth_dev *dev, 70799a2dd95SBruce Richardson struct rte_eth_hairpin_cap *cap); 70899a2dd95SBruce Richardson 70999a2dd95SBruce Richardson /** 71099a2dd95SBruce Richardson * @internal 71109fd4227SAndrew Rybchenko * Setup Rx hairpin queue. 71299a2dd95SBruce Richardson * 71399a2dd95SBruce Richardson * @param dev 71499a2dd95SBruce Richardson * ethdev handle of port. 71599a2dd95SBruce Richardson * @param rx_queue_id 71609fd4227SAndrew Rybchenko * the selected Rx queue index. 71799a2dd95SBruce Richardson * @param nb_rx_desc 71899a2dd95SBruce Richardson * the requested number of descriptors for this queue. 0 - use PMD default. 71999a2dd95SBruce Richardson * @param conf 72009fd4227SAndrew Rybchenko * the Rx hairpin configuration structure. 72199a2dd95SBruce Richardson * 72299a2dd95SBruce Richardson * @return 72399a2dd95SBruce Richardson * Negative errno value on error, 0 on success. 72499a2dd95SBruce Richardson * 72599a2dd95SBruce Richardson * @retval 0 72699a2dd95SBruce Richardson * Success, hairpin is supported. 72799a2dd95SBruce Richardson * @retval -ENOTSUP 72899a2dd95SBruce Richardson * Hairpin is not supported. 72999a2dd95SBruce Richardson * @retval -EINVAL 73099a2dd95SBruce Richardson * One of the parameters is invalid. 73199a2dd95SBruce Richardson * @retval -ENOMEM 73299a2dd95SBruce Richardson * Unable to allocate resources. 73399a2dd95SBruce Richardson */ 73499a2dd95SBruce Richardson typedef int (*eth_rx_hairpin_queue_setup_t) 73599a2dd95SBruce Richardson (struct rte_eth_dev *dev, uint16_t rx_queue_id, 73699a2dd95SBruce Richardson uint16_t nb_rx_desc, 73799a2dd95SBruce Richardson const struct rte_eth_hairpin_conf *conf); 73899a2dd95SBruce Richardson 73999a2dd95SBruce Richardson /** 74099a2dd95SBruce Richardson * @internal 74109fd4227SAndrew Rybchenko * Setup Tx hairpin queue. 74299a2dd95SBruce Richardson * 74399a2dd95SBruce Richardson * @param dev 74499a2dd95SBruce Richardson * ethdev handle of port. 74599a2dd95SBruce Richardson * @param tx_queue_id 74609fd4227SAndrew Rybchenko * the selected Tx queue index. 74799a2dd95SBruce Richardson * @param nb_tx_desc 74899a2dd95SBruce Richardson * the requested number of descriptors for this queue. 0 - use PMD default. 74999a2dd95SBruce Richardson * @param conf 75009fd4227SAndrew Rybchenko * the Tx hairpin configuration structure. 75199a2dd95SBruce Richardson * 75299a2dd95SBruce Richardson * @return 75399a2dd95SBruce Richardson * Negative errno value on error, 0 on success. 75499a2dd95SBruce Richardson * 75599a2dd95SBruce Richardson * @retval 0 75699a2dd95SBruce Richardson * Success, hairpin is supported. 75799a2dd95SBruce Richardson * @retval -ENOTSUP 75899a2dd95SBruce Richardson * Hairpin is not supported. 75999a2dd95SBruce Richardson * @retval -EINVAL 76099a2dd95SBruce Richardson * One of the parameters is invalid. 76199a2dd95SBruce Richardson * @retval -ENOMEM 76299a2dd95SBruce Richardson * Unable to allocate resources. 76399a2dd95SBruce Richardson */ 76499a2dd95SBruce Richardson typedef int (*eth_tx_hairpin_queue_setup_t) 76599a2dd95SBruce Richardson (struct rte_eth_dev *dev, uint16_t tx_queue_id, 76699a2dd95SBruce Richardson uint16_t nb_tx_desc, 76799a2dd95SBruce Richardson const struct rte_eth_hairpin_conf *hairpin_conf); 76899a2dd95SBruce Richardson 76999a2dd95SBruce Richardson /** 77099a2dd95SBruce Richardson * @internal 77199a2dd95SBruce Richardson * Get Forward Error Correction(FEC) capability. 77299a2dd95SBruce Richardson * 77399a2dd95SBruce Richardson * @param dev 77499a2dd95SBruce Richardson * ethdev handle of port. 77599a2dd95SBruce Richardson * @param speed_fec_capa 77699a2dd95SBruce Richardson * speed_fec_capa is out only with per-speed capabilities. 77799a2dd95SBruce Richardson * @param num 77899a2dd95SBruce Richardson * a number of elements in an speed_fec_capa array. 77999a2dd95SBruce Richardson * 78099a2dd95SBruce Richardson * @return 78199a2dd95SBruce Richardson * Negative errno value on error, positive value on success. 78299a2dd95SBruce Richardson * 78399a2dd95SBruce Richardson * @retval positive value 78499a2dd95SBruce Richardson * A non-negative value lower or equal to num: success. The return value 78599a2dd95SBruce Richardson * is the number of entries filled in the fec capa array. 78699a2dd95SBruce Richardson * A non-negative value higher than num: error, the given fec capa array 78799a2dd95SBruce Richardson * is too small. The return value corresponds to the num that should 78899a2dd95SBruce Richardson * be given to succeed. The entries in the fec capa array are not valid 78999a2dd95SBruce Richardson * and shall not be used by the caller. 79099a2dd95SBruce Richardson * @retval -ENOTSUP 79199a2dd95SBruce Richardson * Operation is not supported. 79299a2dd95SBruce Richardson * @retval -EIO 79399a2dd95SBruce Richardson * Device is removed. 79499a2dd95SBruce Richardson * @retval -EINVAL 79599a2dd95SBruce Richardson * *num* or *speed_fec_capa* invalid. 79699a2dd95SBruce Richardson */ 79799a2dd95SBruce Richardson typedef int (*eth_fec_get_capability_t)(struct rte_eth_dev *dev, 79899a2dd95SBruce Richardson struct rte_eth_fec_capa *speed_fec_capa, unsigned int num); 79999a2dd95SBruce Richardson 80099a2dd95SBruce Richardson /** 80199a2dd95SBruce Richardson * @internal 80299a2dd95SBruce Richardson * Get Forward Error Correction(FEC) mode. 80399a2dd95SBruce Richardson * 80499a2dd95SBruce Richardson * @param dev 80599a2dd95SBruce Richardson * ethdev handle of port. 80699a2dd95SBruce Richardson * @param fec_capa 80799a2dd95SBruce Richardson * a bitmask of enabled FEC modes. If AUTO bit is set, other 80899a2dd95SBruce Richardson * bits specify FEC modes which may be negotiated. If AUTO 80999a2dd95SBruce Richardson * bit is clear, specify FEC modes to be used (only one valid 81099a2dd95SBruce Richardson * mode per speed may be set). 81199a2dd95SBruce Richardson * 81299a2dd95SBruce Richardson * @return 81399a2dd95SBruce Richardson * Negative errno value on error, 0 on success. 81499a2dd95SBruce Richardson * 81599a2dd95SBruce Richardson * @retval 0 81699a2dd95SBruce Richardson * Success, get FEC success. 81799a2dd95SBruce Richardson * @retval -ENOTSUP 81899a2dd95SBruce Richardson * Operation is not supported. 81999a2dd95SBruce Richardson * @retval -EIO 82099a2dd95SBruce Richardson * Device is removed. 82199a2dd95SBruce Richardson */ 82299a2dd95SBruce Richardson typedef int (*eth_fec_get_t)(struct rte_eth_dev *dev, 82399a2dd95SBruce Richardson uint32_t *fec_capa); 82499a2dd95SBruce Richardson 82599a2dd95SBruce Richardson /** 82699a2dd95SBruce Richardson * @internal 82799a2dd95SBruce Richardson * Set Forward Error Correction(FEC) mode. 82899a2dd95SBruce Richardson * 82999a2dd95SBruce Richardson * @param dev 83099a2dd95SBruce Richardson * ethdev handle of port. 83199a2dd95SBruce Richardson * @param fec_capa 83299a2dd95SBruce Richardson * bitmask of allowed FEC modes. It must be only one 83399a2dd95SBruce Richardson * if AUTO is disabled. If AUTO is enabled, other 83499a2dd95SBruce Richardson * bits specify FEC modes which may be negotiated. 83599a2dd95SBruce Richardson * 83699a2dd95SBruce Richardson * @return 83799a2dd95SBruce Richardson * Negative errno value on error, 0 on success. 83899a2dd95SBruce Richardson * 83999a2dd95SBruce Richardson * @retval 0 84099a2dd95SBruce Richardson * Success, set FEC success. 84199a2dd95SBruce Richardson * @retval -ENOTSUP 84299a2dd95SBruce Richardson * Operation is not supported. 84399a2dd95SBruce Richardson * @retval -EINVAL 84499a2dd95SBruce Richardson * Unsupported FEC mode requested. 84599a2dd95SBruce Richardson * @retval -EIO 84699a2dd95SBruce Richardson * Device is removed. 84799a2dd95SBruce Richardson */ 84899a2dd95SBruce Richardson typedef int (*eth_fec_set_t)(struct rte_eth_dev *dev, uint32_t fec_capa); 84999a2dd95SBruce Richardson 85099a2dd95SBruce Richardson /** 85199a2dd95SBruce Richardson * @internal 85299a2dd95SBruce Richardson * Get all hairpin Tx/Rx peer ports of the current device, if any. 85399a2dd95SBruce Richardson * 85499a2dd95SBruce Richardson * @param dev 85599a2dd95SBruce Richardson * ethdev handle of port. 85699a2dd95SBruce Richardson * @param peer_ports 85799a2dd95SBruce Richardson * array to save the ports list. 85899a2dd95SBruce Richardson * @param len 85999a2dd95SBruce Richardson * array length. 86099a2dd95SBruce Richardson * @param direction 86199a2dd95SBruce Richardson * value to decide the current to peer direction 86299a2dd95SBruce Richardson * positive - used as Tx to get all peer Rx ports. 86399a2dd95SBruce Richardson * zero - used as Rx to get all peer Tx ports. 86499a2dd95SBruce Richardson * 86599a2dd95SBruce Richardson * @return 86699a2dd95SBruce Richardson * Negative errno value on error, 0 or positive on success. 86799a2dd95SBruce Richardson * 86899a2dd95SBruce Richardson * @retval 0 86999a2dd95SBruce Richardson * Success, no peer ports. 87099a2dd95SBruce Richardson * @retval >0 87199a2dd95SBruce Richardson * Actual number of the peer ports. 87299a2dd95SBruce Richardson * @retval -ENOTSUP 87399a2dd95SBruce Richardson * Get peer ports API is not supported. 87499a2dd95SBruce Richardson * @retval -EINVAL 87599a2dd95SBruce Richardson * One of the parameters is invalid. 87699a2dd95SBruce Richardson */ 87799a2dd95SBruce Richardson typedef int (*hairpin_get_peer_ports_t)(struct rte_eth_dev *dev, 87899a2dd95SBruce Richardson uint16_t *peer_ports, size_t len, 87999a2dd95SBruce Richardson uint32_t direction); 88099a2dd95SBruce Richardson 88199a2dd95SBruce Richardson /** 88299a2dd95SBruce Richardson * @internal 88399a2dd95SBruce Richardson * Bind all hairpin Tx queues of one port to the Rx queues of the peer port. 88499a2dd95SBruce Richardson * 88599a2dd95SBruce Richardson * @param dev 88699a2dd95SBruce Richardson * ethdev handle of port. 88799a2dd95SBruce Richardson * @param rx_port 88899a2dd95SBruce Richardson * the peer Rx port. 88999a2dd95SBruce Richardson * 89099a2dd95SBruce Richardson * @return 89199a2dd95SBruce Richardson * Negative errno value on error, 0 on success. 89299a2dd95SBruce Richardson * 89399a2dd95SBruce Richardson * @retval 0 89499a2dd95SBruce Richardson * Success, bind successfully. 89599a2dd95SBruce Richardson * @retval -ENOTSUP 89699a2dd95SBruce Richardson * Bind API is not supported. 89799a2dd95SBruce Richardson * @retval -EINVAL 89899a2dd95SBruce Richardson * One of the parameters is invalid. 89999a2dd95SBruce Richardson * @retval -EBUSY 90099a2dd95SBruce Richardson * Device is not started. 90199a2dd95SBruce Richardson */ 90299a2dd95SBruce Richardson typedef int (*eth_hairpin_bind_t)(struct rte_eth_dev *dev, 90399a2dd95SBruce Richardson uint16_t rx_port); 90499a2dd95SBruce Richardson 90599a2dd95SBruce Richardson /** 90699a2dd95SBruce Richardson * @internal 90799a2dd95SBruce Richardson * Unbind all hairpin Tx queues of one port from the Rx queues of the peer port. 90899a2dd95SBruce Richardson * 90999a2dd95SBruce Richardson * @param dev 91099a2dd95SBruce Richardson * ethdev handle of port. 91199a2dd95SBruce Richardson * @param rx_port 91299a2dd95SBruce Richardson * the peer Rx port. 91399a2dd95SBruce Richardson * 91499a2dd95SBruce Richardson * @return 91599a2dd95SBruce Richardson * Negative errno value on error, 0 on success. 91699a2dd95SBruce Richardson * 91799a2dd95SBruce Richardson * @retval 0 91899a2dd95SBruce Richardson * Success, unbind successfully. 91999a2dd95SBruce Richardson * @retval -ENOTSUP 92099a2dd95SBruce Richardson * Bind API is not supported. 92199a2dd95SBruce Richardson * @retval -EINVAL 92299a2dd95SBruce Richardson * One of the parameters is invalid. 92399a2dd95SBruce Richardson * @retval -EBUSY 92499a2dd95SBruce Richardson * Device is already stopped. 92599a2dd95SBruce Richardson */ 92699a2dd95SBruce Richardson typedef int (*eth_hairpin_unbind_t)(struct rte_eth_dev *dev, 92799a2dd95SBruce Richardson uint16_t rx_port); 92899a2dd95SBruce Richardson 9293c2ca0a9SAndrew Rybchenko /** @internal Update and fetch peer queue information. */ 93099a2dd95SBruce Richardson typedef int (*eth_hairpin_queue_peer_update_t) 93199a2dd95SBruce Richardson (struct rte_eth_dev *dev, uint16_t peer_queue, 93299a2dd95SBruce Richardson struct rte_hairpin_peer_info *current_info, 93399a2dd95SBruce Richardson struct rte_hairpin_peer_info *peer_info, uint32_t direction); 93499a2dd95SBruce Richardson 9353c2ca0a9SAndrew Rybchenko /** @internal Bind peer queue to the current queue with fetched information. */ 93699a2dd95SBruce Richardson typedef int (*eth_hairpin_queue_peer_bind_t) 93799a2dd95SBruce Richardson (struct rte_eth_dev *dev, uint16_t cur_queue, 93899a2dd95SBruce Richardson struct rte_hairpin_peer_info *peer_info, uint32_t direction); 93999a2dd95SBruce Richardson 9403c2ca0a9SAndrew Rybchenko /** @internal Unbind peer queue from the current queue. */ 94199a2dd95SBruce Richardson typedef int (*eth_hairpin_queue_peer_unbind_t) 94299a2dd95SBruce Richardson (struct rte_eth_dev *dev, uint16_t cur_queue, uint32_t direction); 94399a2dd95SBruce Richardson 94499a2dd95SBruce Richardson /** 94599a2dd95SBruce Richardson * @internal 94699a2dd95SBruce Richardson * Get address of memory location whose contents will change whenever there is 94799a2dd95SBruce Richardson * new data to be received on an Rx queue. 94899a2dd95SBruce Richardson * 94999a2dd95SBruce Richardson * @param rxq 95099a2dd95SBruce Richardson * Ethdev queue pointer. 95199a2dd95SBruce Richardson * @param pmc 95299a2dd95SBruce Richardson * The pointer to power-optimized monitoring condition structure. 95399a2dd95SBruce Richardson * @return 95499a2dd95SBruce Richardson * Negative errno value on error, 0 on success. 95599a2dd95SBruce Richardson * 95699a2dd95SBruce Richardson * @retval 0 95799a2dd95SBruce Richardson * Success 95899a2dd95SBruce Richardson * @retval -EINVAL 95999a2dd95SBruce Richardson * Invalid parameters 96099a2dd95SBruce Richardson */ 96199a2dd95SBruce Richardson typedef int (*eth_get_monitor_addr_t)(void *rxq, 96299a2dd95SBruce Richardson struct rte_power_monitor_cond *pmc); 96399a2dd95SBruce Richardson 96499a2dd95SBruce Richardson /** 96599a2dd95SBruce Richardson * @internal 96699a2dd95SBruce Richardson * Get representor info to be able to calculate the unique representor ID. 96799a2dd95SBruce Richardson * 96899a2dd95SBruce Richardson * Caller should pass NULL as pointer of info to get number of entries, 96999a2dd95SBruce Richardson * allocate info buffer according to returned entry number, then call 97099a2dd95SBruce Richardson * again with buffer to get real info. 97199a2dd95SBruce Richardson * 97299a2dd95SBruce Richardson * To calculate the representor ID, caller should iterate each entry, 97399a2dd95SBruce Richardson * match controller index, pf index, vf or sf start index and range, 97499a2dd95SBruce Richardson * then calculate representor ID from offset to vf/sf start index. 97599a2dd95SBruce Richardson * @see rte_eth_representor_id_get. 97699a2dd95SBruce Richardson * 97799a2dd95SBruce Richardson * @param dev 97899a2dd95SBruce Richardson * Ethdev handle of port. 97999a2dd95SBruce Richardson * @param [out] info 98099a2dd95SBruce Richardson * Pointer to memory to save device representor info. 98199a2dd95SBruce Richardson * @return 98299a2dd95SBruce Richardson * Negative errno value on error, number of info entries otherwise. 98399a2dd95SBruce Richardson */ 98499a2dd95SBruce Richardson 98599a2dd95SBruce Richardson typedef int (*eth_representor_info_get_t)(struct rte_eth_dev *dev, 98699a2dd95SBruce Richardson struct rte_eth_representor_info *info); 98799a2dd95SBruce Richardson 98899a2dd95SBruce Richardson /** 989f6d8a6d3SIvan Malov * @internal 990f6d8a6d3SIvan Malov * Negotiate the NIC's ability to deliver specific kinds of metadata to the PMD. 991f6d8a6d3SIvan Malov * 992f6d8a6d3SIvan Malov * @param dev 993f6d8a6d3SIvan Malov * Port (ethdev) handle 994f6d8a6d3SIvan Malov * 995f6d8a6d3SIvan Malov * @param[inout] features 996f6d8a6d3SIvan Malov * Feature selection buffer 997f6d8a6d3SIvan Malov * 998f6d8a6d3SIvan Malov * @return 999f6d8a6d3SIvan Malov * Negative errno value on error, zero otherwise 1000f6d8a6d3SIvan Malov */ 1001f6d8a6d3SIvan Malov typedef int (*eth_rx_metadata_negotiate_t)(struct rte_eth_dev *dev, 1002f6d8a6d3SIvan Malov uint64_t *features); 1003f6d8a6d3SIvan Malov 1004f6d8a6d3SIvan Malov /** 1005a75ab6e5SAkhil Goyal * @internal 1006a75ab6e5SAkhil Goyal * Get IP reassembly offload capability of a PMD. 1007a75ab6e5SAkhil Goyal * 1008a75ab6e5SAkhil Goyal * @param dev 1009a75ab6e5SAkhil Goyal * Port (ethdev) handle 1010a75ab6e5SAkhil Goyal * 1011a75ab6e5SAkhil Goyal * @param[out] conf 1012a75ab6e5SAkhil Goyal * IP reassembly capability supported by the PMD 1013a75ab6e5SAkhil Goyal * 1014a75ab6e5SAkhil Goyal * @return 1015a75ab6e5SAkhil Goyal * Negative errno value on error, zero otherwise 1016a75ab6e5SAkhil Goyal */ 1017a75ab6e5SAkhil Goyal typedef int (*eth_ip_reassembly_capability_get_t)(struct rte_eth_dev *dev, 1018a75ab6e5SAkhil Goyal struct rte_eth_ip_reassembly_params *capa); 1019a75ab6e5SAkhil Goyal 1020a75ab6e5SAkhil Goyal /** 1021a75ab6e5SAkhil Goyal * @internal 1022a75ab6e5SAkhil Goyal * Get IP reassembly offload configuration parameters set in PMD. 1023a75ab6e5SAkhil Goyal * 1024a75ab6e5SAkhil Goyal * @param dev 1025a75ab6e5SAkhil Goyal * Port (ethdev) handle 1026a75ab6e5SAkhil Goyal * 1027a75ab6e5SAkhil Goyal * @param[out] conf 1028a75ab6e5SAkhil Goyal * Configuration parameters for IP reassembly. 1029a75ab6e5SAkhil Goyal * 1030a75ab6e5SAkhil Goyal * @return 1031a75ab6e5SAkhil Goyal * Negative errno value on error, zero otherwise 1032a75ab6e5SAkhil Goyal */ 1033a75ab6e5SAkhil Goyal typedef int (*eth_ip_reassembly_conf_get_t)(struct rte_eth_dev *dev, 1034a75ab6e5SAkhil Goyal struct rte_eth_ip_reassembly_params *conf); 1035a75ab6e5SAkhil Goyal 1036a75ab6e5SAkhil Goyal /** 1037a75ab6e5SAkhil Goyal * @internal 1038a75ab6e5SAkhil Goyal * Set configuration parameters for enabling IP reassembly offload in hardware. 1039a75ab6e5SAkhil Goyal * 1040a75ab6e5SAkhil Goyal * @param dev 1041a75ab6e5SAkhil Goyal * Port (ethdev) handle 1042a75ab6e5SAkhil Goyal * 1043a75ab6e5SAkhil Goyal * @param[in] conf 1044a75ab6e5SAkhil Goyal * Configuration parameters for IP reassembly. 1045a75ab6e5SAkhil Goyal * 1046a75ab6e5SAkhil Goyal * @return 1047a75ab6e5SAkhil Goyal * Negative errno value on error, zero otherwise 1048a75ab6e5SAkhil Goyal */ 1049a75ab6e5SAkhil Goyal typedef int (*eth_ip_reassembly_conf_set_t)(struct rte_eth_dev *dev, 1050a75ab6e5SAkhil Goyal const struct rte_eth_ip_reassembly_params *conf); 1051a75ab6e5SAkhil Goyal 1052a75ab6e5SAkhil Goyal /** 1053edcf22c6SMin Hu (Connor) * @internal 1054edcf22c6SMin Hu (Connor) * Dump private info from device to a file. 1055edcf22c6SMin Hu (Connor) * 1056edcf22c6SMin Hu (Connor) * @param dev 1057edcf22c6SMin Hu (Connor) * Port (ethdev) handle. 1058edcf22c6SMin Hu (Connor) * @param file 1059edcf22c6SMin Hu (Connor) * A pointer to a file for output. 1060edcf22c6SMin Hu (Connor) * 1061edcf22c6SMin Hu (Connor) * @return 1062edcf22c6SMin Hu (Connor) * Negative value on error, 0 on success. 1063edcf22c6SMin Hu (Connor) * 1064edcf22c6SMin Hu (Connor) * @retval 0 1065edcf22c6SMin Hu (Connor) * Success 1066edcf22c6SMin Hu (Connor) * @retval -EINVAL 1067edcf22c6SMin Hu (Connor) * Invalid file 1068edcf22c6SMin Hu (Connor) */ 1069edcf22c6SMin Hu (Connor) typedef int (*eth_dev_priv_dump_t)(struct rte_eth_dev *dev, FILE *file); 1070edcf22c6SMin Hu (Connor) 1071edcf22c6SMin Hu (Connor) /** 107299a2dd95SBruce Richardson * @internal A structure containing the functions exported by an Ethernet driver. 107399a2dd95SBruce Richardson */ 107499a2dd95SBruce Richardson struct eth_dev_ops { 107555645ee6SAndrew Rybchenko eth_dev_configure_t dev_configure; /**< Configure device */ 107655645ee6SAndrew Rybchenko eth_dev_start_t dev_start; /**< Start device */ 107755645ee6SAndrew Rybchenko eth_dev_stop_t dev_stop; /**< Stop device */ 107855645ee6SAndrew Rybchenko eth_dev_set_link_up_t dev_set_link_up; /**< Device link up */ 107955645ee6SAndrew Rybchenko eth_dev_set_link_down_t dev_set_link_down; /**< Device link down */ 108055645ee6SAndrew Rybchenko eth_dev_close_t dev_close; /**< Close device */ 108155645ee6SAndrew Rybchenko eth_dev_reset_t dev_reset; /**< Reset device */ 108255645ee6SAndrew Rybchenko eth_link_update_t link_update; /**< Get device link state */ 10833c2ca0a9SAndrew Rybchenko /** Check if the device was physically removed */ 108499a2dd95SBruce Richardson eth_is_removed_t is_removed; 108599a2dd95SBruce Richardson 108655645ee6SAndrew Rybchenko eth_promiscuous_enable_t promiscuous_enable; /**< Promiscuous ON */ 108755645ee6SAndrew Rybchenko eth_promiscuous_disable_t promiscuous_disable;/**< Promiscuous OFF */ 108855645ee6SAndrew Rybchenko eth_allmulticast_enable_t allmulticast_enable;/**< Rx multicast ON */ 108955645ee6SAndrew Rybchenko eth_allmulticast_disable_t allmulticast_disable;/**< Rx multicast OFF */ 109055645ee6SAndrew Rybchenko eth_mac_addr_remove_t mac_addr_remove; /**< Remove MAC address */ 109155645ee6SAndrew Rybchenko eth_mac_addr_add_t mac_addr_add; /**< Add a MAC address */ 109255645ee6SAndrew Rybchenko eth_mac_addr_set_t mac_addr_set; /**< Set a MAC address */ 10933c2ca0a9SAndrew Rybchenko /** Set list of multicast addresses */ 10943c2ca0a9SAndrew Rybchenko eth_set_mc_addr_list_t set_mc_addr_list; 109555645ee6SAndrew Rybchenko mtu_set_t mtu_set; /**< Set MTU */ 109699a2dd95SBruce Richardson 10973c2ca0a9SAndrew Rybchenko /** Get generic device statistics */ 10983c2ca0a9SAndrew Rybchenko eth_stats_get_t stats_get; 10993c2ca0a9SAndrew Rybchenko /** Reset generic device statistics */ 11003c2ca0a9SAndrew Rybchenko eth_stats_reset_t stats_reset; 11013c2ca0a9SAndrew Rybchenko /** Get extended device statistics */ 11023c2ca0a9SAndrew Rybchenko eth_xstats_get_t xstats_get; 11033c2ca0a9SAndrew Rybchenko /** Reset extended device statistics */ 11043c2ca0a9SAndrew Rybchenko eth_xstats_reset_t xstats_reset; 11053c2ca0a9SAndrew Rybchenko /** Get names of extended statistics */ 110699a2dd95SBruce Richardson eth_xstats_get_names_t xstats_get_names; 11073c2ca0a9SAndrew Rybchenko /** Configure per queue stat counter mapping */ 110899a2dd95SBruce Richardson eth_queue_stats_mapping_set_t queue_stats_mapping_set; 110999a2dd95SBruce Richardson 111055645ee6SAndrew Rybchenko eth_dev_infos_get_t dev_infos_get; /**< Get device info */ 11113c2ca0a9SAndrew Rybchenko /** Retrieve Rx queue information */ 11123c2ca0a9SAndrew Rybchenko eth_rxq_info_get_t rxq_info_get; 11133c2ca0a9SAndrew Rybchenko /** Retrieve Tx queue information */ 11143c2ca0a9SAndrew Rybchenko eth_txq_info_get_t txq_info_get; 111509fd4227SAndrew Rybchenko eth_burst_mode_get_t rx_burst_mode_get; /**< Get Rx burst mode */ 111609fd4227SAndrew Rybchenko eth_burst_mode_get_t tx_burst_mode_get; /**< Get Tx burst mode */ 111755645ee6SAndrew Rybchenko eth_fw_version_get_t fw_version_get; /**< Get firmware version */ 111899a2dd95SBruce Richardson 11193c2ca0a9SAndrew Rybchenko /** Get packet types supported and identified by device */ 11203c2ca0a9SAndrew Rybchenko eth_dev_supported_ptypes_get_t dev_supported_ptypes_get; 11213c2ca0a9SAndrew Rybchenko /** 11223c2ca0a9SAndrew Rybchenko * Inform Ethernet device about reduced range of packet types to 11233c2ca0a9SAndrew Rybchenko * handle 11243c2ca0a9SAndrew Rybchenko */ 11253c2ca0a9SAndrew Rybchenko eth_dev_ptypes_set_t dev_ptypes_set; 11263c2ca0a9SAndrew Rybchenko 11273c2ca0a9SAndrew Rybchenko /** Filter VLAN Setup */ 11283c2ca0a9SAndrew Rybchenko vlan_filter_set_t vlan_filter_set; 11293c2ca0a9SAndrew Rybchenko /** Outer/Inner VLAN TPID Setup */ 11303c2ca0a9SAndrew Rybchenko vlan_tpid_set_t vlan_tpid_set; 11313c2ca0a9SAndrew Rybchenko /** VLAN Stripping on queue */ 11323c2ca0a9SAndrew Rybchenko vlan_strip_queue_set_t vlan_strip_queue_set; 11333c2ca0a9SAndrew Rybchenko /** Set VLAN Offload */ 11343c2ca0a9SAndrew Rybchenko vlan_offload_set_t vlan_offload_set; 11353c2ca0a9SAndrew Rybchenko /** Set port based Tx VLAN insertion */ 11363c2ca0a9SAndrew Rybchenko vlan_pvid_set_t vlan_pvid_set; 113799a2dd95SBruce Richardson 113855645ee6SAndrew Rybchenko eth_queue_start_t rx_queue_start;/**< Start Rx for a queue */ 113955645ee6SAndrew Rybchenko eth_queue_stop_t rx_queue_stop; /**< Stop Rx for a queue */ 114055645ee6SAndrew Rybchenko eth_queue_start_t tx_queue_start;/**< Start Tx for a queue */ 114155645ee6SAndrew Rybchenko eth_queue_stop_t tx_queue_stop; /**< Stop Tx for a queue */ 114255645ee6SAndrew Rybchenko eth_rx_queue_setup_t rx_queue_setup;/**< Set up device Rx queue */ 114355645ee6SAndrew Rybchenko eth_queue_release_t rx_queue_release; /**< Release Rx queue */ 114499a2dd95SBruce Richardson 11453c2ca0a9SAndrew Rybchenko /** Enable Rx queue interrupt */ 11463c2ca0a9SAndrew Rybchenko eth_rx_enable_intr_t rx_queue_intr_enable; 11473c2ca0a9SAndrew Rybchenko /** Disable Rx queue interrupt */ 11483c2ca0a9SAndrew Rybchenko eth_rx_disable_intr_t rx_queue_intr_disable; 11493c2ca0a9SAndrew Rybchenko 115009fd4227SAndrew Rybchenko eth_tx_queue_setup_t tx_queue_setup;/**< Set up device Tx queue */ 115109fd4227SAndrew Rybchenko eth_queue_release_t tx_queue_release; /**< Release Tx queue */ 115209fd4227SAndrew Rybchenko eth_tx_done_cleanup_t tx_done_cleanup;/**< Free Tx ring mbufs */ 115399a2dd95SBruce Richardson 115455645ee6SAndrew Rybchenko eth_dev_led_on_t dev_led_on; /**< Turn on LED */ 115555645ee6SAndrew Rybchenko eth_dev_led_off_t dev_led_off; /**< Turn off LED */ 115699a2dd95SBruce Richardson 115755645ee6SAndrew Rybchenko flow_ctrl_get_t flow_ctrl_get; /**< Get flow control */ 115855645ee6SAndrew Rybchenko flow_ctrl_set_t flow_ctrl_set; /**< Setup flow control */ 11593c2ca0a9SAndrew Rybchenko /** Setup priority flow control */ 11603c2ca0a9SAndrew Rybchenko priority_flow_ctrl_set_t priority_flow_ctrl_set; 11610de345e9SJerin Jacob /** Priority flow control queue info get */ 11620de345e9SJerin Jacob priority_flow_ctrl_queue_info_get_t priority_flow_ctrl_queue_info_get; 11630de345e9SJerin Jacob /** Priority flow control queue configure */ 11640de345e9SJerin Jacob priority_flow_ctrl_queue_config_t priority_flow_ctrl_queue_config; 116599a2dd95SBruce Richardson 11663c2ca0a9SAndrew Rybchenko /** Set Unicast Table Array */ 11673c2ca0a9SAndrew Rybchenko eth_uc_hash_table_set_t uc_hash_table_set; 11683c2ca0a9SAndrew Rybchenko /** Set Unicast hash bitmap */ 11693c2ca0a9SAndrew Rybchenko eth_uc_all_hash_table_set_t uc_all_hash_table_set; 117099a2dd95SBruce Richardson 11713c2ca0a9SAndrew Rybchenko /** Add UDP tunnel port */ 11723c2ca0a9SAndrew Rybchenko eth_udp_tunnel_port_add_t udp_tunnel_port_add; 11733c2ca0a9SAndrew Rybchenko /** Delete UDP tunnel port */ 11743c2ca0a9SAndrew Rybchenko eth_udp_tunnel_port_del_t udp_tunnel_port_del; 117599a2dd95SBruce Richardson 11763c2ca0a9SAndrew Rybchenko /** Set queue rate limit */ 11773c2ca0a9SAndrew Rybchenko eth_set_queue_rate_limit_t set_queue_rate_limit; 117899a2dd95SBruce Richardson 11793c2ca0a9SAndrew Rybchenko /** Configure RSS hash protocols and hashing key */ 11803c2ca0a9SAndrew Rybchenko rss_hash_update_t rss_hash_update; 11813c2ca0a9SAndrew Rybchenko /** Get current RSS hash configuration */ 11823c2ca0a9SAndrew Rybchenko rss_hash_conf_get_t rss_hash_conf_get; 11833c2ca0a9SAndrew Rybchenko /** Update redirection table */ 11843c2ca0a9SAndrew Rybchenko reta_update_t reta_update; 11853c2ca0a9SAndrew Rybchenko /** Query redirection table */ 11863c2ca0a9SAndrew Rybchenko reta_query_t reta_query; 118799a2dd95SBruce Richardson 118855645ee6SAndrew Rybchenko eth_get_reg_t get_reg; /**< Get registers */ 118955645ee6SAndrew Rybchenko eth_get_eeprom_length_t get_eeprom_length; /**< Get EEPROM length */ 119055645ee6SAndrew Rybchenko eth_get_eeprom_t get_eeprom; /**< Get EEPROM data */ 119155645ee6SAndrew Rybchenko eth_set_eeprom_t set_eeprom; /**< Set EEPROM */ 119299a2dd95SBruce Richardson 1193bf73419dSAndrew Rybchenko /** Get plugin module EEPROM attribute */ 119499a2dd95SBruce Richardson eth_get_module_info_t get_module_info; 1195bf73419dSAndrew Rybchenko /** Get plugin module EEPROM data */ 119699a2dd95SBruce Richardson eth_get_module_eeprom_t get_module_eeprom; 119799a2dd95SBruce Richardson 119855645ee6SAndrew Rybchenko eth_flow_ops_get_t flow_ops_get; /**< Get flow operations */ 119999a2dd95SBruce Richardson 12003c2ca0a9SAndrew Rybchenko eth_get_dcb_info get_dcb_info; /**< Get DCB information */ 120199a2dd95SBruce Richardson 12023c2ca0a9SAndrew Rybchenko /** Turn IEEE1588/802.1AS timestamping on */ 120399a2dd95SBruce Richardson eth_timesync_enable_t timesync_enable; 12043c2ca0a9SAndrew Rybchenko /** Turn IEEE1588/802.1AS timestamping off */ 120599a2dd95SBruce Richardson eth_timesync_disable_t timesync_disable; 12063c2ca0a9SAndrew Rybchenko /** Read the IEEE1588/802.1AS Rx timestamp */ 120799a2dd95SBruce Richardson eth_timesync_read_rx_timestamp_t timesync_read_rx_timestamp; 12083c2ca0a9SAndrew Rybchenko /** Read the IEEE1588/802.1AS Tx timestamp */ 120999a2dd95SBruce Richardson eth_timesync_read_tx_timestamp_t timesync_read_tx_timestamp; 12103c2ca0a9SAndrew Rybchenko /** Adjust the device clock */ 12113c2ca0a9SAndrew Rybchenko eth_timesync_adjust_time timesync_adjust_time; 12123c2ca0a9SAndrew Rybchenko /** Get the device clock time */ 12133c2ca0a9SAndrew Rybchenko eth_timesync_read_time timesync_read_time; 12143c2ca0a9SAndrew Rybchenko /** Set the device clock time */ 12153c2ca0a9SAndrew Rybchenko eth_timesync_write_time timesync_write_time; 121699a2dd95SBruce Richardson 121799a2dd95SBruce Richardson eth_read_clock read_clock; 121899a2dd95SBruce Richardson 12193c2ca0a9SAndrew Rybchenko /** Get extended device statistic values by ID */ 122099a2dd95SBruce Richardson eth_xstats_get_by_id_t xstats_get_by_id; 12213c2ca0a9SAndrew Rybchenko /** Get name of extended device statistics by ID */ 122299a2dd95SBruce Richardson eth_xstats_get_names_by_id_t xstats_get_names_by_id; 122399a2dd95SBruce Richardson 12243c2ca0a9SAndrew Rybchenko /** Get Traffic Management (TM) operations */ 122599a2dd95SBruce Richardson eth_tm_ops_get_t tm_ops_get; 122699a2dd95SBruce Richardson 12273c2ca0a9SAndrew Rybchenko /** Get Traffic Metering and Policing (MTR) operations */ 122899a2dd95SBruce Richardson eth_mtr_ops_get_t mtr_ops_get; 122999a2dd95SBruce Richardson 12303c2ca0a9SAndrew Rybchenko /** Test if a port supports specific mempool ops */ 123199a2dd95SBruce Richardson eth_pool_ops_supported_t pool_ops_supported; 123299a2dd95SBruce Richardson 12333c2ca0a9SAndrew Rybchenko /** Returns the hairpin capabilities */ 123499a2dd95SBruce Richardson eth_hairpin_cap_get_t hairpin_cap_get; 12353c2ca0a9SAndrew Rybchenko /** Set up device Rx hairpin queue */ 123699a2dd95SBruce Richardson eth_rx_hairpin_queue_setup_t rx_hairpin_queue_setup; 12373c2ca0a9SAndrew Rybchenko /** Set up device Tx hairpin queue */ 123899a2dd95SBruce Richardson eth_tx_hairpin_queue_setup_t tx_hairpin_queue_setup; 123999a2dd95SBruce Richardson 12403c2ca0a9SAndrew Rybchenko /** Get Forward Error Correction(FEC) capability */ 124199a2dd95SBruce Richardson eth_fec_get_capability_t fec_get_capability; 12423c2ca0a9SAndrew Rybchenko /** Get Forward Error Correction(FEC) mode */ 124399a2dd95SBruce Richardson eth_fec_get_t fec_get; 12443c2ca0a9SAndrew Rybchenko /** Set Forward Error Correction(FEC) mode */ 124599a2dd95SBruce Richardson eth_fec_set_t fec_set; 12463c2ca0a9SAndrew Rybchenko 12473c2ca0a9SAndrew Rybchenko /** Get hairpin peer ports list */ 124899a2dd95SBruce Richardson hairpin_get_peer_ports_t hairpin_get_peer_ports; 12493c2ca0a9SAndrew Rybchenko /** Bind all hairpin Tx queues of device to the peer port Rx queues */ 125099a2dd95SBruce Richardson eth_hairpin_bind_t hairpin_bind; 12513c2ca0a9SAndrew Rybchenko /** Unbind all hairpin Tx queues from the peer port Rx queues */ 125299a2dd95SBruce Richardson eth_hairpin_unbind_t hairpin_unbind; 12533c2ca0a9SAndrew Rybchenko /** Pass the current queue info and get the peer queue info */ 125499a2dd95SBruce Richardson eth_hairpin_queue_peer_update_t hairpin_queue_peer_update; 12553c2ca0a9SAndrew Rybchenko /** Set up the connection between the pair of hairpin queues */ 125699a2dd95SBruce Richardson eth_hairpin_queue_peer_bind_t hairpin_queue_peer_bind; 12573c2ca0a9SAndrew Rybchenko /** Disconnect the hairpin queues of a pair from each other */ 125899a2dd95SBruce Richardson eth_hairpin_queue_peer_unbind_t hairpin_queue_peer_unbind; 125999a2dd95SBruce Richardson 12603c2ca0a9SAndrew Rybchenko /** Get power monitoring condition for Rx queue */ 126199a2dd95SBruce Richardson eth_get_monitor_addr_t get_monitor_addr; 126299a2dd95SBruce Richardson 12633c2ca0a9SAndrew Rybchenko /** Get representor info */ 126499a2dd95SBruce Richardson eth_representor_info_get_t representor_info_get; 1265f6d8a6d3SIvan Malov 1266f6d8a6d3SIvan Malov /** 1267f6d8a6d3SIvan Malov * Negotiate the NIC's ability to deliver specific 126855645ee6SAndrew Rybchenko * kinds of metadata to the PMD 1269f6d8a6d3SIvan Malov */ 1270f6d8a6d3SIvan Malov eth_rx_metadata_negotiate_t rx_metadata_negotiate; 1271a75ab6e5SAkhil Goyal 1272a75ab6e5SAkhil Goyal /** Get IP reassembly capability */ 1273a75ab6e5SAkhil Goyal eth_ip_reassembly_capability_get_t ip_reassembly_capability_get; 1274a75ab6e5SAkhil Goyal /** Get IP reassembly configuration */ 1275a75ab6e5SAkhil Goyal eth_ip_reassembly_conf_get_t ip_reassembly_conf_get; 1276a75ab6e5SAkhil Goyal /** Set IP reassembly configuration */ 1277a75ab6e5SAkhil Goyal eth_ip_reassembly_conf_set_t ip_reassembly_conf_set; 1278edcf22c6SMin Hu (Connor) 1279edcf22c6SMin Hu (Connor) /** Dump private info from device */ 1280edcf22c6SMin Hu (Connor) eth_dev_priv_dump_t eth_dev_priv_dump; 128199a2dd95SBruce Richardson }; 128299a2dd95SBruce Richardson 128399a2dd95SBruce Richardson /** 128499a2dd95SBruce Richardson * @internal 128599a2dd95SBruce Richardson * Check if the selected Rx queue is hairpin queue. 128699a2dd95SBruce Richardson * 128799a2dd95SBruce Richardson * @param dev 128899a2dd95SBruce Richardson * Pointer to the selected device. 128999a2dd95SBruce Richardson * @param queue_id 129099a2dd95SBruce Richardson * The selected queue. 129199a2dd95SBruce Richardson * 129299a2dd95SBruce Richardson * @return 129399a2dd95SBruce Richardson * - (1) if the queue is hairpin queue, 0 otherwise. 129499a2dd95SBruce Richardson */ 129599a2dd95SBruce Richardson __rte_internal 129699a2dd95SBruce Richardson int rte_eth_dev_is_rx_hairpin_queue(struct rte_eth_dev *dev, uint16_t queue_id); 129799a2dd95SBruce Richardson 129899a2dd95SBruce Richardson /** 129999a2dd95SBruce Richardson * @internal 130099a2dd95SBruce Richardson * Check if the selected Tx queue is hairpin queue. 130199a2dd95SBruce Richardson * 130299a2dd95SBruce Richardson * @param dev 130399a2dd95SBruce Richardson * Pointer to the selected device. 130499a2dd95SBruce Richardson * @param queue_id 130599a2dd95SBruce Richardson * The selected queue. 130699a2dd95SBruce Richardson * 130799a2dd95SBruce Richardson * @return 130899a2dd95SBruce Richardson * - (1) if the queue is hairpin queue, 0 otherwise. 130999a2dd95SBruce Richardson */ 131099a2dd95SBruce Richardson __rte_internal 131199a2dd95SBruce Richardson int rte_eth_dev_is_tx_hairpin_queue(struct rte_eth_dev *dev, uint16_t queue_id); 131299a2dd95SBruce Richardson 131399a2dd95SBruce Richardson /** 131499a2dd95SBruce Richardson * @internal 131599a2dd95SBruce Richardson * Returns a ethdev slot specified by the unique identifier name. 131699a2dd95SBruce Richardson * 131799a2dd95SBruce Richardson * @param name 131899a2dd95SBruce Richardson * The pointer to the Unique identifier name for each Ethernet device 131999a2dd95SBruce Richardson * @return 132099a2dd95SBruce Richardson * - The pointer to the ethdev slot, on success. NULL on error 132199a2dd95SBruce Richardson */ 132299a2dd95SBruce Richardson __rte_internal 132399a2dd95SBruce Richardson struct rte_eth_dev *rte_eth_dev_allocated(const char *name); 132499a2dd95SBruce Richardson 132599a2dd95SBruce Richardson /** 132699a2dd95SBruce Richardson * @internal 13270d9f56a8SAndrew Rybchenko * Allocates a new ethdev slot for an Ethernet device and returns the pointer 132899a2dd95SBruce Richardson * to that slot for the driver to use. 132999a2dd95SBruce Richardson * 133099a2dd95SBruce Richardson * @param name Unique identifier name for each Ethernet device 133199a2dd95SBruce Richardson * @return 133299a2dd95SBruce Richardson * - Slot in the rte_dev_devices array for a new device; 133399a2dd95SBruce Richardson */ 133499a2dd95SBruce Richardson __rte_internal 133599a2dd95SBruce Richardson struct rte_eth_dev *rte_eth_dev_allocate(const char *name); 133699a2dd95SBruce Richardson 133799a2dd95SBruce Richardson /** 133899a2dd95SBruce Richardson * @internal 133999a2dd95SBruce Richardson * Attach to the ethdev already initialized by the primary 134099a2dd95SBruce Richardson * process. 134199a2dd95SBruce Richardson * 134299a2dd95SBruce Richardson * @param name Ethernet device's name. 134399a2dd95SBruce Richardson * @return 134499a2dd95SBruce Richardson * - Success: Slot in the rte_dev_devices array for attached 134599a2dd95SBruce Richardson * device. 134699a2dd95SBruce Richardson * - Error: Null pointer. 134799a2dd95SBruce Richardson */ 134899a2dd95SBruce Richardson __rte_internal 134999a2dd95SBruce Richardson struct rte_eth_dev *rte_eth_dev_attach_secondary(const char *name); 135099a2dd95SBruce Richardson 135199a2dd95SBruce Richardson /** 135299a2dd95SBruce Richardson * @internal 135399a2dd95SBruce Richardson * Notify RTE_ETH_EVENT_DESTROY and release the specified ethdev port. 135499a2dd95SBruce Richardson * 135599a2dd95SBruce Richardson * The following PMD-managed data fields will be freed: 135699a2dd95SBruce Richardson * - dev_private 135799a2dd95SBruce Richardson * - mac_addrs 135899a2dd95SBruce Richardson * - hash_mac_addrs 135999a2dd95SBruce Richardson * If one of these fields should not be freed, 136099a2dd95SBruce Richardson * it must be reset to NULL by the PMD, typically in dev_close method. 136199a2dd95SBruce Richardson * 136299a2dd95SBruce Richardson * @param eth_dev 136399a2dd95SBruce Richardson * Device to be detached. 136499a2dd95SBruce Richardson * @return 136599a2dd95SBruce Richardson * - 0 on success, negative on error 136699a2dd95SBruce Richardson */ 136799a2dd95SBruce Richardson __rte_internal 136899a2dd95SBruce Richardson int rte_eth_dev_release_port(struct rte_eth_dev *eth_dev); 136999a2dd95SBruce Richardson 137099a2dd95SBruce Richardson /** 137199a2dd95SBruce Richardson * @internal 137299a2dd95SBruce Richardson * Release device queues and clear its configuration to force the user 137399a2dd95SBruce Richardson * application to reconfigure it. It is for internal use only. 137499a2dd95SBruce Richardson * 137599a2dd95SBruce Richardson * @param dev 137699a2dd95SBruce Richardson * Pointer to struct rte_eth_dev. 137799a2dd95SBruce Richardson * 137899a2dd95SBruce Richardson * @return 137999a2dd95SBruce Richardson * void 138099a2dd95SBruce Richardson */ 138199a2dd95SBruce Richardson __rte_internal 138299a2dd95SBruce Richardson void rte_eth_dev_internal_reset(struct rte_eth_dev *dev); 138399a2dd95SBruce Richardson 138499a2dd95SBruce Richardson /** 138599a2dd95SBruce Richardson * @internal Executes all the user application registered callbacks for 138699a2dd95SBruce Richardson * the specific device. It is for DPDK internal user only. User 138799a2dd95SBruce Richardson * application should not call it directly. 138899a2dd95SBruce Richardson * 138999a2dd95SBruce Richardson * @param dev 139099a2dd95SBruce Richardson * Pointer to struct rte_eth_dev. 139199a2dd95SBruce Richardson * @param event 139299a2dd95SBruce Richardson * Eth device interrupt event type. 139399a2dd95SBruce Richardson * @param ret_param 139499a2dd95SBruce Richardson * To pass data back to user application. 139599a2dd95SBruce Richardson * This allows the user application to decide if a particular function 139699a2dd95SBruce Richardson * is permitted or not. 139799a2dd95SBruce Richardson * 139899a2dd95SBruce Richardson * @return 139999a2dd95SBruce Richardson * int 140099a2dd95SBruce Richardson */ 140199a2dd95SBruce Richardson __rte_internal 140299a2dd95SBruce Richardson int rte_eth_dev_callback_process(struct rte_eth_dev *dev, 140399a2dd95SBruce Richardson enum rte_eth_event_type event, void *ret_param); 140499a2dd95SBruce Richardson 140599a2dd95SBruce Richardson /** 140699a2dd95SBruce Richardson * @internal 140799a2dd95SBruce Richardson * This is the last step of device probing. 140899a2dd95SBruce Richardson * It must be called after a port is allocated and initialized successfully. 140999a2dd95SBruce Richardson * 141099a2dd95SBruce Richardson * The notification RTE_ETH_EVENT_NEW is sent to other entities 141199a2dd95SBruce Richardson * (libraries and applications). 141299a2dd95SBruce Richardson * The state is set as RTE_ETH_DEV_ATTACHED. 141399a2dd95SBruce Richardson * 141499a2dd95SBruce Richardson * @param dev 141599a2dd95SBruce Richardson * New ethdev port. 141699a2dd95SBruce Richardson */ 141799a2dd95SBruce Richardson __rte_internal 141899a2dd95SBruce Richardson void rte_eth_dev_probing_finish(struct rte_eth_dev *dev); 141999a2dd95SBruce Richardson 142099a2dd95SBruce Richardson /** 142199a2dd95SBruce Richardson * Create memzone for HW rings. 142299a2dd95SBruce Richardson * malloc can't be used as the physical address is needed. 142399a2dd95SBruce Richardson * If the memzone is already created, then this function returns a ptr 142499a2dd95SBruce Richardson * to the old one. 142599a2dd95SBruce Richardson * 142699a2dd95SBruce Richardson * @param eth_dev 142799a2dd95SBruce Richardson * The *eth_dev* pointer is the address of the *rte_eth_dev* structure 142899a2dd95SBruce Richardson * @param name 142999a2dd95SBruce Richardson * The name of the memory zone 143099a2dd95SBruce Richardson * @param queue_id 143199a2dd95SBruce Richardson * The index of the queue to add to name 143299a2dd95SBruce Richardson * @param size 143399a2dd95SBruce Richardson * The sizeof of the memory area 143499a2dd95SBruce Richardson * @param align 143599a2dd95SBruce Richardson * Alignment for resulting memzone. Must be a power of 2. 143699a2dd95SBruce Richardson * @param socket_id 143799a2dd95SBruce Richardson * The *socket_id* argument is the socket identifier in case of NUMA. 143899a2dd95SBruce Richardson */ 143999a2dd95SBruce Richardson __rte_internal 144099a2dd95SBruce Richardson const struct rte_memzone * 144199a2dd95SBruce Richardson rte_eth_dma_zone_reserve(const struct rte_eth_dev *eth_dev, const char *name, 144299a2dd95SBruce Richardson uint16_t queue_id, size_t size, 144399a2dd95SBruce Richardson unsigned align, int socket_id); 144499a2dd95SBruce Richardson 144599a2dd95SBruce Richardson /** 144699a2dd95SBruce Richardson * Free previously allocated memzone for HW rings. 144799a2dd95SBruce Richardson * 144899a2dd95SBruce Richardson * @param eth_dev 144999a2dd95SBruce Richardson * The *eth_dev* pointer is the address of the *rte_eth_dev* structure 145099a2dd95SBruce Richardson * @param name 145199a2dd95SBruce Richardson * The name of the memory zone 145299a2dd95SBruce Richardson * @param queue_id 145399a2dd95SBruce Richardson * The index of the queue to add to name 145499a2dd95SBruce Richardson * @return 145599a2dd95SBruce Richardson * Negative errno value on error, 0 on success. 145699a2dd95SBruce Richardson */ 145799a2dd95SBruce Richardson __rte_internal 145899a2dd95SBruce Richardson int 145999a2dd95SBruce Richardson rte_eth_dma_zone_free(const struct rte_eth_dev *eth_dev, const char *name, 146099a2dd95SBruce Richardson uint16_t queue_id); 146199a2dd95SBruce Richardson 146299a2dd95SBruce Richardson /** 146399a2dd95SBruce Richardson * @internal 146499a2dd95SBruce Richardson * Atomically set the link status for the specific device. 146599a2dd95SBruce Richardson * It is for use by DPDK device driver use only. 146699a2dd95SBruce Richardson * User applications should not call it 146799a2dd95SBruce Richardson * 146899a2dd95SBruce Richardson * @param dev 146999a2dd95SBruce Richardson * Pointer to struct rte_eth_dev. 147099a2dd95SBruce Richardson * @param link 147199a2dd95SBruce Richardson * New link status value. 147299a2dd95SBruce Richardson * @return 147399a2dd95SBruce Richardson * Same convention as eth_link_update operation. 147499a2dd95SBruce Richardson * 0 if link up status has changed 147599a2dd95SBruce Richardson * -1 if link up status was unchanged 147699a2dd95SBruce Richardson */ 147799a2dd95SBruce Richardson static inline int 147899a2dd95SBruce Richardson rte_eth_linkstatus_set(struct rte_eth_dev *dev, 147999a2dd95SBruce Richardson const struct rte_eth_link *new_link) 148099a2dd95SBruce Richardson { 148199a2dd95SBruce Richardson uint64_t *dev_link = (uint64_t *)&(dev->data->dev_link); 148299a2dd95SBruce Richardson union { 148399a2dd95SBruce Richardson uint64_t val64; 148499a2dd95SBruce Richardson struct rte_eth_link link; 148599a2dd95SBruce Richardson } orig; 148699a2dd95SBruce Richardson 148799a2dd95SBruce Richardson RTE_BUILD_BUG_ON(sizeof(*new_link) != sizeof(uint64_t)); 148899a2dd95SBruce Richardson 148999a2dd95SBruce Richardson orig.val64 = __atomic_exchange_n(dev_link, *(const uint64_t *)new_link, 149099a2dd95SBruce Richardson __ATOMIC_SEQ_CST); 149199a2dd95SBruce Richardson 149299a2dd95SBruce Richardson return (orig.link.link_status == new_link->link_status) ? -1 : 0; 149399a2dd95SBruce Richardson } 149499a2dd95SBruce Richardson 149599a2dd95SBruce Richardson /** 149699a2dd95SBruce Richardson * @internal 149799a2dd95SBruce Richardson * Atomically get the link speed and status. 149899a2dd95SBruce Richardson * 149999a2dd95SBruce Richardson * @param dev 150099a2dd95SBruce Richardson * Pointer to struct rte_eth_dev. 150199a2dd95SBruce Richardson * @param link 150299a2dd95SBruce Richardson * link status value. 150399a2dd95SBruce Richardson */ 150499a2dd95SBruce Richardson static inline void 150599a2dd95SBruce Richardson rte_eth_linkstatus_get(const struct rte_eth_dev *dev, 150699a2dd95SBruce Richardson struct rte_eth_link *link) 150799a2dd95SBruce Richardson { 150899a2dd95SBruce Richardson uint64_t *src = (uint64_t *)&(dev->data->dev_link); 150999a2dd95SBruce Richardson uint64_t *dst = (uint64_t *)link; 151099a2dd95SBruce Richardson 151199a2dd95SBruce Richardson RTE_BUILD_BUG_ON(sizeof(*link) != sizeof(uint64_t)); 151299a2dd95SBruce Richardson 151399a2dd95SBruce Richardson *dst = __atomic_load_n(src, __ATOMIC_SEQ_CST); 151499a2dd95SBruce Richardson } 151599a2dd95SBruce Richardson 151699a2dd95SBruce Richardson /** 1517a41f593fSFerruh Yigit * @internal 1518a41f593fSFerruh Yigit * Dummy DPDK callback for Rx/Tx packet burst. 1519a41f593fSFerruh Yigit * 1520a41f593fSFerruh Yigit * @param queue 1521a41f593fSFerruh Yigit * Pointer to Rx/Tx queue 1522a41f593fSFerruh Yigit * @param pkts 1523a41f593fSFerruh Yigit * Packet array 1524a41f593fSFerruh Yigit * @param nb_pkts 1525a41f593fSFerruh Yigit * Number of packets in packet array 1526a41f593fSFerruh Yigit */ 1527a41f593fSFerruh Yigit __rte_internal 1528a41f593fSFerruh Yigit uint16_t 1529a41f593fSFerruh Yigit rte_eth_pkt_burst_dummy(void *queue __rte_unused, 1530a41f593fSFerruh Yigit struct rte_mbuf **pkts __rte_unused, 1531a41f593fSFerruh Yigit uint16_t nb_pkts __rte_unused); 1532a41f593fSFerruh Yigit 1533a41f593fSFerruh Yigit /** 153499a2dd95SBruce Richardson * Allocate an unique switch domain identifier. 153599a2dd95SBruce Richardson * 153699a2dd95SBruce Richardson * A pool of switch domain identifiers which can be allocated on request. This 153799a2dd95SBruce Richardson * will enabled devices which support the concept of switch domains to request 15385906be5aSAndrew Rybchenko * a switch domain ID which is guaranteed to be unique from other devices 153999a2dd95SBruce Richardson * running in the same process. 154099a2dd95SBruce Richardson * 154199a2dd95SBruce Richardson * @param domain_id 154299a2dd95SBruce Richardson * switch domain identifier parameter to pass back to application 154399a2dd95SBruce Richardson * 154499a2dd95SBruce Richardson * @return 154599a2dd95SBruce Richardson * Negative errno value on error, 0 on success. 154699a2dd95SBruce Richardson */ 154799a2dd95SBruce Richardson __rte_internal 154899a2dd95SBruce Richardson int 154999a2dd95SBruce Richardson rte_eth_switch_domain_alloc(uint16_t *domain_id); 155099a2dd95SBruce Richardson 155199a2dd95SBruce Richardson /** 155299a2dd95SBruce Richardson * Free switch domain. 155399a2dd95SBruce Richardson * 155499a2dd95SBruce Richardson * Return a switch domain identifier to the pool of free identifiers after it is 155599a2dd95SBruce Richardson * no longer in use by device. 155699a2dd95SBruce Richardson * 155799a2dd95SBruce Richardson * @param domain_id 155899a2dd95SBruce Richardson * switch domain identifier to free 155999a2dd95SBruce Richardson * 156099a2dd95SBruce Richardson * @return 156199a2dd95SBruce Richardson * Negative errno value on error, 0 on success. 156299a2dd95SBruce Richardson */ 156399a2dd95SBruce Richardson __rte_internal 156499a2dd95SBruce Richardson int 156599a2dd95SBruce Richardson rte_eth_switch_domain_free(uint16_t domain_id); 156699a2dd95SBruce Richardson 156799a2dd95SBruce Richardson /** 156899a2dd95SBruce Richardson * Generic Ethernet device arguments 156999a2dd95SBruce Richardson * 157099a2dd95SBruce Richardson * One type of representor each structure. 157199a2dd95SBruce Richardson */ 157299a2dd95SBruce Richardson struct rte_eth_devargs { 157399a2dd95SBruce Richardson uint16_t mh_controllers[RTE_MAX_MULTI_HOST_CTRLS]; 157499a2dd95SBruce Richardson /** controller/s number in case of multi-host */ 157599a2dd95SBruce Richardson uint16_t nb_mh_controllers; 157699a2dd95SBruce Richardson /** number of controllers in multi-host controllers field */ 157799a2dd95SBruce Richardson uint16_t ports[RTE_MAX_ETHPORTS]; 157899a2dd95SBruce Richardson /** port/s number to enable on a multi-port single function */ 157999a2dd95SBruce Richardson uint16_t nb_ports; 158099a2dd95SBruce Richardson /** number of ports in ports field */ 158199a2dd95SBruce Richardson uint16_t representor_ports[RTE_MAX_ETHPORTS]; 158299a2dd95SBruce Richardson /** representor port/s identifier to enable on device */ 158399a2dd95SBruce Richardson uint16_t nb_representor_ports; 158499a2dd95SBruce Richardson /** number of ports in representor port field */ 158599a2dd95SBruce Richardson enum rte_eth_representor_type type; /* type of representor */ 158699a2dd95SBruce Richardson }; 158799a2dd95SBruce Richardson 158899a2dd95SBruce Richardson /** 158999a2dd95SBruce Richardson * PMD helper function to get representor ID from location detail. 159099a2dd95SBruce Richardson * 159199a2dd95SBruce Richardson * Get representor ID from controller, pf and (sf or vf). 159299a2dd95SBruce Richardson * The mapping is retrieved from rte_eth_representor_info_get(). 159399a2dd95SBruce Richardson * 159499a2dd95SBruce Richardson * For backward compatibility, if no representor info, direct 159599a2dd95SBruce Richardson * map legacy VF (no controller and pf). 159699a2dd95SBruce Richardson * 1597ff4e52efSViacheslav Galaktionov * @param port_id 1598ff4e52efSViacheslav Galaktionov * Port ID of the backing device. 159999a2dd95SBruce Richardson * @param type 160099a2dd95SBruce Richardson * Representor type. 160199a2dd95SBruce Richardson * @param controller 160299a2dd95SBruce Richardson * Controller ID, -1 if unspecified. 160399a2dd95SBruce Richardson * @param pf 160499a2dd95SBruce Richardson * PF port ID, -1 if unspecified. 160599a2dd95SBruce Richardson * @param representor_port 160699a2dd95SBruce Richardson * VF or SF representor port number, -1 if unspecified. 160799a2dd95SBruce Richardson * @param repr_id 160899a2dd95SBruce Richardson * Pointer to output representor ID. 160999a2dd95SBruce Richardson * 161099a2dd95SBruce Richardson * @return 161199a2dd95SBruce Richardson * Negative errno value on error, 0 on success. 161299a2dd95SBruce Richardson */ 161399a2dd95SBruce Richardson __rte_internal 161499a2dd95SBruce Richardson int 1615ff4e52efSViacheslav Galaktionov rte_eth_representor_id_get(uint16_t port_id, 161699a2dd95SBruce Richardson enum rte_eth_representor_type type, 161799a2dd95SBruce Richardson int controller, int pf, int representor_port, 161899a2dd95SBruce Richardson uint16_t *repr_id); 161999a2dd95SBruce Richardson 162099a2dd95SBruce Richardson /** 162199a2dd95SBruce Richardson * PMD helper function to parse ethdev arguments 162299a2dd95SBruce Richardson * 162399a2dd95SBruce Richardson * @param devargs 162499a2dd95SBruce Richardson * device arguments 162599a2dd95SBruce Richardson * @param eth_devargs 162699a2dd95SBruce Richardson * parsed ethdev specific arguments. 162799a2dd95SBruce Richardson * 162899a2dd95SBruce Richardson * @return 162999a2dd95SBruce Richardson * Negative errno value on error, 0 on success. 163099a2dd95SBruce Richardson */ 163199a2dd95SBruce Richardson __rte_internal 163299a2dd95SBruce Richardson int 163399a2dd95SBruce Richardson rte_eth_devargs_parse(const char *devargs, struct rte_eth_devargs *eth_devargs); 163499a2dd95SBruce Richardson 163599a2dd95SBruce Richardson 163699a2dd95SBruce Richardson typedef int (*ethdev_init_t)(struct rte_eth_dev *ethdev, void *init_params); 163799a2dd95SBruce Richardson typedef int (*ethdev_bus_specific_init)(struct rte_eth_dev *ethdev, 163899a2dd95SBruce Richardson void *bus_specific_init_params); 163999a2dd95SBruce Richardson 164099a2dd95SBruce Richardson /** 164199a2dd95SBruce Richardson * PMD helper function for the creation of a new ethdev ports. 164299a2dd95SBruce Richardson * 164399a2dd95SBruce Richardson * @param device 164499a2dd95SBruce Richardson * rte_device handle. 164599a2dd95SBruce Richardson * @param name 164699a2dd95SBruce Richardson * port name. 164799a2dd95SBruce Richardson * @param priv_data_size 164899a2dd95SBruce Richardson * size of private data required for port. 164999a2dd95SBruce Richardson * @param bus_specific_init 165099a2dd95SBruce Richardson * port bus specific initialisation callback function 165199a2dd95SBruce Richardson * @param bus_init_params 165299a2dd95SBruce Richardson * port bus specific initialisation parameters 165399a2dd95SBruce Richardson * @param ethdev_init 165499a2dd95SBruce Richardson * device specific port initialization callback function 165599a2dd95SBruce Richardson * @param init_params 165699a2dd95SBruce Richardson * port initialisation parameters 165799a2dd95SBruce Richardson * 165899a2dd95SBruce Richardson * @return 165999a2dd95SBruce Richardson * Negative errno value on error, 0 on success. 166099a2dd95SBruce Richardson */ 166199a2dd95SBruce Richardson __rte_internal 166299a2dd95SBruce Richardson int 166399a2dd95SBruce Richardson rte_eth_dev_create(struct rte_device *device, const char *name, 166499a2dd95SBruce Richardson size_t priv_data_size, 166599a2dd95SBruce Richardson ethdev_bus_specific_init bus_specific_init, void *bus_init_params, 166699a2dd95SBruce Richardson ethdev_init_t ethdev_init, void *init_params); 166799a2dd95SBruce Richardson 166899a2dd95SBruce Richardson 166999a2dd95SBruce Richardson typedef int (*ethdev_uninit_t)(struct rte_eth_dev *ethdev); 167099a2dd95SBruce Richardson 167199a2dd95SBruce Richardson /** 167299a2dd95SBruce Richardson * PMD helper function for cleaning up the resources of a ethdev port on it's 167399a2dd95SBruce Richardson * destruction. 167499a2dd95SBruce Richardson * 167599a2dd95SBruce Richardson * @param ethdev 167699a2dd95SBruce Richardson * ethdev handle of port. 167799a2dd95SBruce Richardson * @param ethdev_uninit 167899a2dd95SBruce Richardson * device specific port un-initialise callback function 167999a2dd95SBruce Richardson * 168099a2dd95SBruce Richardson * @return 168199a2dd95SBruce Richardson * Negative errno value on error, 0 on success. 168299a2dd95SBruce Richardson */ 168399a2dd95SBruce Richardson __rte_internal 168499a2dd95SBruce Richardson int 168599a2dd95SBruce Richardson rte_eth_dev_destroy(struct rte_eth_dev *ethdev, ethdev_uninit_t ethdev_uninit); 168699a2dd95SBruce Richardson 168799a2dd95SBruce Richardson /** 168899a2dd95SBruce Richardson * @internal 168999a2dd95SBruce Richardson * Pass the current hairpin queue HW and/or SW information to the peer queue 169099a2dd95SBruce Richardson * and fetch back the information of the peer queue. 169199a2dd95SBruce Richardson * 169299a2dd95SBruce Richardson * @param peer_port 169399a2dd95SBruce Richardson * Peer port identifier of the Ethernet device. 169499a2dd95SBruce Richardson * @param peer_queue 169599a2dd95SBruce Richardson * Peer queue index of the port. 169699a2dd95SBruce Richardson * @param cur_info 169799a2dd95SBruce Richardson * Pointer to the current information structure. 169899a2dd95SBruce Richardson * @param peer_info 169999a2dd95SBruce Richardson * Pointer to the peer information, output. 170099a2dd95SBruce Richardson * @param direction 170199a2dd95SBruce Richardson * Direction to pass the information. 170299a2dd95SBruce Richardson * positive - pass Tx queue information and get peer Rx queue information 170399a2dd95SBruce Richardson * zero - pass Rx queue information and get peer Tx queue information 170499a2dd95SBruce Richardson * 170599a2dd95SBruce Richardson * @return 170699a2dd95SBruce Richardson * Negative errno value on error, 0 on success. 170799a2dd95SBruce Richardson */ 170899a2dd95SBruce Richardson __rte_internal 170999a2dd95SBruce Richardson int 171099a2dd95SBruce Richardson rte_eth_hairpin_queue_peer_update(uint16_t peer_port, uint16_t peer_queue, 171199a2dd95SBruce Richardson struct rte_hairpin_peer_info *cur_info, 171299a2dd95SBruce Richardson struct rte_hairpin_peer_info *peer_info, 171399a2dd95SBruce Richardson uint32_t direction); 171499a2dd95SBruce Richardson 171599a2dd95SBruce Richardson /** 171699a2dd95SBruce Richardson * @internal 171799a2dd95SBruce Richardson * Configure current hairpin queue with the peer information fetched to create 171899a2dd95SBruce Richardson * the connection (bind) with peer queue in the specified direction. 171999a2dd95SBruce Richardson * This function might need to be called twice to fully create the connections. 172099a2dd95SBruce Richardson * 172199a2dd95SBruce Richardson * @param cur_port 172299a2dd95SBruce Richardson * Current port identifier of the Ethernet device. 172399a2dd95SBruce Richardson * @param cur_queue 172499a2dd95SBruce Richardson * Current queue index of the port. 172599a2dd95SBruce Richardson * @param peer_info 172699a2dd95SBruce Richardson * Pointer to the peer information, input. 172799a2dd95SBruce Richardson * @param direction 172899a2dd95SBruce Richardson * Direction to create the connection. 172999a2dd95SBruce Richardson * positive - bind current Tx queue to peer Rx queue 173099a2dd95SBruce Richardson * zero - bind current Rx queue to peer Tx queue 173199a2dd95SBruce Richardson * 173299a2dd95SBruce Richardson * @return 173399a2dd95SBruce Richardson * Negative errno value on error, 0 on success. 173499a2dd95SBruce Richardson */ 173599a2dd95SBruce Richardson __rte_internal 173699a2dd95SBruce Richardson int 173799a2dd95SBruce Richardson rte_eth_hairpin_queue_peer_bind(uint16_t cur_port, uint16_t cur_queue, 173899a2dd95SBruce Richardson struct rte_hairpin_peer_info *peer_info, 173999a2dd95SBruce Richardson uint32_t direction); 174099a2dd95SBruce Richardson 174199a2dd95SBruce Richardson /** 174299a2dd95SBruce Richardson * @internal 1743961fb402SKumara Parameshwaran * Get rte_eth_dev from device name. The device name should be specified 1744961fb402SKumara Parameshwaran * as below: 1745961fb402SKumara Parameshwaran * - PCIe address (Domain:Bus:Device.Function), for example 0000:2:00.0 1746961fb402SKumara Parameshwaran * - SoC device name, for example fsl-gmac0 1747961fb402SKumara Parameshwaran * - vdev dpdk name, for example net_[pcap0|null0|tap0] 1748961fb402SKumara Parameshwaran * 1749961fb402SKumara Parameshwaran * @param name 1750961fb402SKumara Parameshwaran * PCI address or name of the device 1751961fb402SKumara Parameshwaran * @return 1752961fb402SKumara Parameshwaran * - rte_eth_dev if successful 1753961fb402SKumara Parameshwaran * - NULL on failure 1754961fb402SKumara Parameshwaran */ 1755961fb402SKumara Parameshwaran __rte_internal 1756961fb402SKumara Parameshwaran struct rte_eth_dev* 1757961fb402SKumara Parameshwaran rte_eth_dev_get_by_name(const char *name); 1758961fb402SKumara Parameshwaran 1759961fb402SKumara Parameshwaran /** 1760961fb402SKumara Parameshwaran * @internal 176199a2dd95SBruce Richardson * Reset the current queue state and configuration to disconnect (unbind) it 176299a2dd95SBruce Richardson * from the peer queue. 176399a2dd95SBruce Richardson * This function might need to be called twice to disconnect each other. 176499a2dd95SBruce Richardson * 176599a2dd95SBruce Richardson * @param cur_port 176699a2dd95SBruce Richardson * Current port identifier of the Ethernet device. 176799a2dd95SBruce Richardson * @param cur_queue 176899a2dd95SBruce Richardson * Current queue index of the port. 176999a2dd95SBruce Richardson * @param direction 177099a2dd95SBruce Richardson * Direction to destroy the connection. 177199a2dd95SBruce Richardson * positive - unbind current Tx queue from peer Rx queue 177299a2dd95SBruce Richardson * zero - unbind current Rx queue from peer Tx queue 177399a2dd95SBruce Richardson * 177499a2dd95SBruce Richardson * @return 177599a2dd95SBruce Richardson * Negative errno value on error, 0 on success. 177699a2dd95SBruce Richardson */ 177799a2dd95SBruce Richardson __rte_internal 177899a2dd95SBruce Richardson int 177999a2dd95SBruce Richardson rte_eth_hairpin_queue_peer_unbind(uint16_t cur_port, uint16_t cur_queue, 178099a2dd95SBruce Richardson uint32_t direction); 178199a2dd95SBruce Richardson 17823c059b2cSAkhil Goyal /** 17833c059b2cSAkhil Goyal * @internal 17843c059b2cSAkhil Goyal * Register mbuf dynamic field and flag for IP reassembly incomplete case. 17853c059b2cSAkhil Goyal */ 17863c059b2cSAkhil Goyal __rte_internal 17873c059b2cSAkhil Goyal int 17883c059b2cSAkhil Goyal rte_eth_ip_reassembly_dynfield_register(int *field_offset, int *flag); 17893c059b2cSAkhil Goyal 179099a2dd95SBruce Richardson 179199a2dd95SBruce Richardson /* 179299a2dd95SBruce Richardson * Legacy ethdev API used internally by drivers. 179399a2dd95SBruce Richardson */ 179499a2dd95SBruce Richardson 179599a2dd95SBruce Richardson enum rte_filter_type { 179699a2dd95SBruce Richardson RTE_ETH_FILTER_NONE = 0, 179799a2dd95SBruce Richardson RTE_ETH_FILTER_ETHERTYPE, 179899a2dd95SBruce Richardson RTE_ETH_FILTER_FLEXIBLE, 179999a2dd95SBruce Richardson RTE_ETH_FILTER_SYN, 180099a2dd95SBruce Richardson RTE_ETH_FILTER_NTUPLE, 180199a2dd95SBruce Richardson RTE_ETH_FILTER_TUNNEL, 180299a2dd95SBruce Richardson RTE_ETH_FILTER_FDIR, 180399a2dd95SBruce Richardson RTE_ETH_FILTER_HASH, 180499a2dd95SBruce Richardson RTE_ETH_FILTER_L2_TUNNEL, 180599a2dd95SBruce Richardson }; 180699a2dd95SBruce Richardson 180799a2dd95SBruce Richardson /** 180899a2dd95SBruce Richardson * Define all structures for Ethertype Filter type. 180999a2dd95SBruce Richardson */ 181099a2dd95SBruce Richardson 181199a2dd95SBruce Richardson #define RTE_ETHTYPE_FLAGS_MAC 0x0001 /**< If set, compare mac */ 181299a2dd95SBruce Richardson #define RTE_ETHTYPE_FLAGS_DROP 0x0002 /**< If set, drop packet when match */ 181399a2dd95SBruce Richardson 181499a2dd95SBruce Richardson /** 181599a2dd95SBruce Richardson * A structure used to define the ethertype filter entry 181699a2dd95SBruce Richardson * to support RTE_ETH_FILTER_ETHERTYPE data representation. 181799a2dd95SBruce Richardson */ 181899a2dd95SBruce Richardson struct rte_eth_ethertype_filter { 181955645ee6SAndrew Rybchenko struct rte_ether_addr mac_addr; /**< Mac address to match */ 182099a2dd95SBruce Richardson uint16_t ether_type; /**< Ether type to match */ 182199a2dd95SBruce Richardson uint16_t flags; /**< Flags from RTE_ETHTYPE_FLAGS_* */ 182299a2dd95SBruce Richardson uint16_t queue; /**< Queue assigned to when match */ 182399a2dd95SBruce Richardson }; 182499a2dd95SBruce Richardson 182599a2dd95SBruce Richardson /** 182699a2dd95SBruce Richardson * A structure used to define the TCP syn filter entry 182799a2dd95SBruce Richardson * to support RTE_ETH_FILTER_SYN data representation. 182899a2dd95SBruce Richardson */ 182999a2dd95SBruce Richardson struct rte_eth_syn_filter { 183055645ee6SAndrew Rybchenko /** 1 - higher priority than other filters, 0 - lower priority */ 183199a2dd95SBruce Richardson uint8_t hig_pri; 183299a2dd95SBruce Richardson uint16_t queue; /**< Queue assigned to when match */ 183399a2dd95SBruce Richardson }; 183499a2dd95SBruce Richardson 183599a2dd95SBruce Richardson /** 183699a2dd95SBruce Richardson * filter type of tunneling packet 183799a2dd95SBruce Richardson */ 1838295968d1SFerruh Yigit #define RTE_ETH_TUNNEL_FILTER_OMAC 0x01 /**< filter by outer MAC addr */ 1839295968d1SFerruh Yigit #define RTE_ETH_TUNNEL_FILTER_OIP 0x02 /**< filter by outer IP Addr */ 1840295968d1SFerruh Yigit #define RTE_ETH_TUNNEL_FILTER_TENID 0x04 /**< filter by tenant ID */ 1841295968d1SFerruh Yigit #define RTE_ETH_TUNNEL_FILTER_IMAC 0x08 /**< filter by inner MAC addr */ 1842295968d1SFerruh Yigit #define RTE_ETH_TUNNEL_FILTER_IVLAN 0x10 /**< filter by inner VLAN ID */ 1843295968d1SFerruh Yigit #define RTE_ETH_TUNNEL_FILTER_IIP 0x20 /**< filter by inner IP addr */ 184499a2dd95SBruce Richardson 1845295968d1SFerruh Yigit #define RTE_ETH_TUNNEL_FILTER_IMAC_IVLAN (RTE_ETH_TUNNEL_FILTER_IMAC | \ 1846295968d1SFerruh Yigit RTE_ETH_TUNNEL_FILTER_IVLAN) 1847295968d1SFerruh Yigit #define RTE_ETH_TUNNEL_FILTER_IMAC_IVLAN_TENID (RTE_ETH_TUNNEL_FILTER_IMAC | \ 1848295968d1SFerruh Yigit RTE_ETH_TUNNEL_FILTER_IVLAN | \ 1849295968d1SFerruh Yigit RTE_ETH_TUNNEL_FILTER_TENID) 1850295968d1SFerruh Yigit #define RTE_ETH_TUNNEL_FILTER_IMAC_TENID (RTE_ETH_TUNNEL_FILTER_IMAC | \ 1851295968d1SFerruh Yigit RTE_ETH_TUNNEL_FILTER_TENID) 1852295968d1SFerruh Yigit #define RTE_ETH_TUNNEL_FILTER_OMAC_TENID_IMAC (RTE_ETH_TUNNEL_FILTER_OMAC | \ 1853295968d1SFerruh Yigit RTE_ETH_TUNNEL_FILTER_TENID | \ 1854295968d1SFerruh Yigit RTE_ETH_TUNNEL_FILTER_IMAC) 185599a2dd95SBruce Richardson 185699a2dd95SBruce Richardson /** 185799a2dd95SBruce Richardson * Select IPv4 or IPv6 for tunnel filters. 185899a2dd95SBruce Richardson */ 185999a2dd95SBruce Richardson enum rte_tunnel_iptype { 186055645ee6SAndrew Rybchenko RTE_TUNNEL_IPTYPE_IPV4 = 0, /**< IPv4 */ 186155645ee6SAndrew Rybchenko RTE_TUNNEL_IPTYPE_IPV6, /**< IPv6 */ 186299a2dd95SBruce Richardson }; 186399a2dd95SBruce Richardson 186499a2dd95SBruce Richardson /** 186599a2dd95SBruce Richardson * Tunneling Packet filter configuration. 186699a2dd95SBruce Richardson */ 186799a2dd95SBruce Richardson struct rte_eth_tunnel_filter_conf { 186855645ee6SAndrew Rybchenko struct rte_ether_addr outer_mac; /**< Outer MAC address to match */ 186955645ee6SAndrew Rybchenko struct rte_ether_addr inner_mac; /**< Inner MAC address to match */ 187055645ee6SAndrew Rybchenko uint16_t inner_vlan; /**< Inner VLAN to match */ 187155645ee6SAndrew Rybchenko enum rte_tunnel_iptype ip_type; /**< IP address type */ 187299a2dd95SBruce Richardson /** 187399a2dd95SBruce Richardson * Outer destination IP address to match if ETH_TUNNEL_FILTER_OIP 187499a2dd95SBruce Richardson * is set in filter_type, or inner destination IP address to match 187599a2dd95SBruce Richardson * if ETH_TUNNEL_FILTER_IIP is set in filter_type. 187699a2dd95SBruce Richardson */ 187799a2dd95SBruce Richardson union { 187855645ee6SAndrew Rybchenko uint32_t ipv4_addr; /**< IPv4 address in big endian */ 187955645ee6SAndrew Rybchenko uint32_t ipv6_addr[4]; /**< IPv6 address in big endian */ 188099a2dd95SBruce Richardson } ip_addr; 188155645ee6SAndrew Rybchenko /** Flags from ETH_TUNNEL_FILTER_XX - see above */ 188299a2dd95SBruce Richardson uint16_t filter_type; 188355645ee6SAndrew Rybchenko enum rte_eth_tunnel_type tunnel_type; /**< Tunnel Type */ 188455645ee6SAndrew Rybchenko uint32_t tenant_id; /**< Tenant ID to match: VNI, GRE key... */ 188555645ee6SAndrew Rybchenko uint16_t queue_id; /**< Queue assigned to if match */ 188699a2dd95SBruce Richardson }; 188799a2dd95SBruce Richardson 1888*dbf9fc1dSBrian Dooley #ifdef __cplusplus 1889*dbf9fc1dSBrian Dooley } 1890*dbf9fc1dSBrian Dooley #endif 1891*dbf9fc1dSBrian Dooley 189299a2dd95SBruce Richardson #endif /* _RTE_ETHDEV_DRIVER_H_ */ 1893