[dpdk-dev] [RFC] net/ena: use dynamic log type for debug logging
Michał Krawczyk
mk at semihalf.com
Tue Aug 27 14:51:59 CEST 2019
wt., 16 lip 2019 o 22:43 Stephen Hemminger
<stephen at networkplumber.org> napisał(a):
>
> The generic RTE_LOGTYPE_PMD is a historical relic and should
> not be used. Every driver must use dynamic logtypes.
>
> Compile tested only!
>
> Signed-off-by: Stephen Hemminger <stephen at networkplumber.org>
Tested-by: Michal Krawczyk <mk at semihalf.com>
> ---
> drivers/net/ena/base/ena_plat_dpdk.h | 20 ++--
> drivers/net/ena/ena_ethdev.c | 167 ++++++++++++++++-----------
> drivers/net/ena/ena_logs.h | 18 ++-
> 3 files changed, 125 insertions(+), 80 deletions(-)
>
> diff --git a/drivers/net/ena/base/ena_plat_dpdk.h b/drivers/net/ena/base/ena_plat_dpdk.h
> index 902d91efbe38..0909bfc4835d 100644
> --- a/drivers/net/ena/base/ena_plat_dpdk.h
> +++ b/drivers/net/ena/base/ena_plat_dpdk.h
> @@ -98,11 +98,13 @@ typedef uint64_t dma_addr_t;
> #define ENA_GET_SYSTEM_USECS() \
> (rte_get_timer_cycles() * US_PER_S / rte_get_timer_hz())
>
> +extern int ena_logtype_com;
> #if RTE_LOG_DP_LEVEL >= RTE_LOG_DEBUG
> #define ENA_ASSERT(cond, format, arg...) \
> do { \
> if (unlikely(!(cond))) { \
> - RTE_LOG(ERR, PMD, format, ##arg); \
> + rte_log(RTE_LOGTYPE_ERR, ena_logtype_com, \
> + format, ##arg); \
> rte_panic("line %d\tassert \"" #cond "\"" \
> "failed\n", __LINE__); \
> } \
> @@ -127,14 +129,14 @@ typedef uint64_t dma_addr_t;
> (~0ULL >> (BITS_PER_LONG_LONG - 1 - (h))))
>
> #ifdef RTE_LIBRTE_ENA_COM_DEBUG
> -#define ena_trc_dbg(format, arg...) \
> - RTE_LOG(DEBUG, PMD, "[ENA_COM: %s] " format, __func__, ##arg)
> -#define ena_trc_info(format, arg...) \
> - RTE_LOG(INFO, PMD, "[ENA_COM: %s] " format, __func__, ##arg)
> -#define ena_trc_warn(format, arg...) \
> - RTE_LOG(ERR, PMD, "[ENA_COM: %s] " format, __func__, ##arg)
> -#define ena_trc_err(format, arg...) \
> - RTE_LOG(ERR, PMD, "[ENA_COM: %s] " format, __func__, ##arg)
> +#define ena_trc_log(level, fmt, arg...) \
> + rte_log(RTE_LOG_ ## level, ena_logtype_com, \
> + "[ENA_COM: %s]" fmt, __func__, ##arg)
> +
> +#define ena_trc_dbg(format, arg...) ena_trc_log(DEBUG, format, ##arg)
> +#define ena_trc_info(format, arg...) ena_trc_log(INFO, format, ##arg)
> +#define ena_trc_warn(format, arg...) ena_trc_log(WARNING, format, ##arg)
> +#define ena_trc_err(format, arg...) ena_trc_log(ERR, format, ##arg)
> #else
> #define ena_trc_dbg(format, arg...) do { } while (0)
> #define ena_trc_info(format, arg...) do { } while (0)
> diff --git a/drivers/net/ena/ena_ethdev.c b/drivers/net/ena/ena_ethdev.c
> index f5833408044c..4a67298e9d1f 100644
> --- a/drivers/net/ena/ena_ethdev.c
> +++ b/drivers/net/ena/ena_ethdev.c
> @@ -178,6 +178,19 @@ static const struct ena_stats ena_stats_rx_strings[] = {
> int ena_logtype_init;
> int ena_logtype_driver;
>
> +#ifdef RTE_LIBRTE_ENA_DEBUG_RX
> +int ena_logtype_rx;
> +#endif
> +#ifdef RTE_LIBRTE_ENA_DEBUG_TX
> +int ena_logtype_tx;
> +#endif
> +#ifdef RTE_LIBRTE_ENA_DEBUG_TX_FREE
> +int ena_logtype_tx_free;
> +#endif
> +#ifdef RTE_LIBRTE_ENA_COM_DEBUG
> +int ena_logtype_com;
> +#endif
> +
> static const struct rte_pci_id pci_id_ena_map[] = {
> { RTE_PCI_DEVICE(PCI_VENDOR_ID_AMAZON, PCI_DEVICE_ID_ENA_VF) },
> { RTE_PCI_DEVICE(PCI_VENDOR_ID_AMAZON, PCI_DEVICE_ID_ENA_LLQ_VF) },
> @@ -358,7 +371,7 @@ static inline int validate_rx_req_id(struct ena_ring *rx_ring, uint16_t req_id)
> if (likely(req_id < rx_ring->ring_size))
> return 0;
>
> - RTE_LOG(ERR, PMD, "Invalid rx req_id: %hu\n", req_id);
> + PMD_DRV_LOG(ERR, "Invalid rx req_id: %hu\n", req_id);
>
> rx_ring->adapter->reset_reason = ENA_REGS_RESET_INV_RX_REQ_ID;
> rx_ring->adapter->trigger_reset = true;
> @@ -378,9 +391,9 @@ static int validate_tx_req_id(struct ena_ring *tx_ring, u16 req_id)
> }
>
> if (tx_info)
> - RTE_LOG(ERR, PMD, "tx_info doesn't have valid mbuf\n");
> + PMD_DRV_LOG(ERR, "tx_info doesn't have valid mbuf\n");
> else
> - RTE_LOG(ERR, PMD, "Invalid req_id: %hu\n", req_id);
> + PMD_DRV_LOG(ERR, "Invalid req_id: %hu\n", req_id);
>
> /* Trigger device reset */
> ++tx_ring->tx_stats.bad_req_id;
> @@ -397,7 +410,7 @@ static void ena_config_host_info(struct ena_com_dev *ena_dev)
> /* Allocate only the host info */
> rc = ena_com_allocate_host_info(ena_dev);
> if (rc) {
> - RTE_LOG(ERR, PMD, "Cannot allocate host info\n");
> + PMD_DRV_LOG(ERR, "Cannot allocate host info\n");
> return;
> }
>
> @@ -420,9 +433,9 @@ static void ena_config_host_info(struct ena_com_dev *ena_dev)
> rc = ena_com_set_host_attributes(ena_dev);
> if (rc) {
> if (rc == -ENA_COM_UNSUPPORTED)
> - RTE_LOG(WARNING, PMD, "Cannot set host attributes\n");
> + PMD_DRV_LOG(WARNING, "Cannot set host attributes\n");
> else
> - RTE_LOG(ERR, PMD, "Cannot set host attributes\n");
> + PMD_DRV_LOG(ERR, "Cannot set host attributes\n");
>
> goto err;
> }
> @@ -453,16 +466,16 @@ static void ena_config_debug_area(struct ena_adapter *adapter)
>
> rc = ena_com_allocate_debug_area(&adapter->ena_dev, debug_area_size);
> if (rc) {
> - RTE_LOG(ERR, PMD, "Cannot allocate debug area\n");
> + PMD_DRV_LOG(ERR, "Cannot allocate debug area\n");
> return;
> }
>
> rc = ena_com_set_host_attributes(&adapter->ena_dev);
> if (rc) {
> if (rc == -ENA_COM_UNSUPPORTED)
> - RTE_LOG(WARNING, PMD, "Cannot set host attributes\n");
> + PMD_DRV_LOG(WARNING, "Cannot set host attributes\n");
> else
> - RTE_LOG(ERR, PMD, "Cannot set host attributes\n");
> + PMD_DRV_LOG(ERR, "Cannot set host attributes\n");
>
> goto err;
> }
> @@ -528,7 +541,7 @@ static int ena_rss_reta_update(struct rte_eth_dev *dev,
> return -EINVAL;
>
> if (reta_size > ENA_RX_RSS_TABLE_SIZE) {
> - RTE_LOG(WARNING, PMD,
> + PMD_DRV_LOG(WARNING,
> "indirection table %d is bigger than supported (%d)\n",
> reta_size, ENA_RX_RSS_TABLE_SIZE);
> return -EINVAL;
> @@ -548,7 +561,7 @@ static int ena_rss_reta_update(struct rte_eth_dev *dev,
> i,
> entry_value);
> if (unlikely(rc && rc != ENA_COM_UNSUPPORTED)) {
> - RTE_LOG(ERR, PMD,
> + PMD_DRV_LOG(ERR,
> "Cannot fill indirect table\n");
> return rc;
> }
> @@ -557,11 +570,11 @@ static int ena_rss_reta_update(struct rte_eth_dev *dev,
>
> rc = ena_com_indirect_table_set(ena_dev);
> if (unlikely(rc && rc != ENA_COM_UNSUPPORTED)) {
> - RTE_LOG(ERR, PMD, "Cannot flush the indirect table\n");
> + PMD_DRV_LOG(ERR, "Cannot flush the indirect table\n");
> return rc;
> }
>
> - RTE_LOG(DEBUG, PMD, "%s(): RSS configured %d entries for port %d\n",
> + PMD_DRV_LOG(DEBUG, "%s(): RSS configured %d entries for port %d\n",
> __func__, reta_size, adapter->rte_dev->data->port_id);
>
> return 0;
> @@ -586,7 +599,7 @@ static int ena_rss_reta_query(struct rte_eth_dev *dev,
>
> rc = ena_com_indirect_table_get(ena_dev, indirect_table);
> if (unlikely(rc && rc != ENA_COM_UNSUPPORTED)) {
> - RTE_LOG(ERR, PMD, "cannot get indirect table\n");
> + PMD_DRV_LOG(ERR, "cannot get indirect table\n");
> return -ENOTSUP;
> }
>
> @@ -610,7 +623,7 @@ static int ena_rss_init_default(struct ena_adapter *adapter)
>
> rc = ena_com_rss_init(ena_dev, ENA_RX_RSS_TABLE_LOG_SIZE);
> if (unlikely(rc)) {
> - RTE_LOG(ERR, PMD, "Cannot init indirect table\n");
> + PMD_DRV_LOG(ERR, "Cannot init indirect table\n");
> goto err_rss_init;
> }
>
> @@ -619,7 +632,7 @@ static int ena_rss_init_default(struct ena_adapter *adapter)
> rc = ena_com_indirect_table_fill_entry(ena_dev, i,
> ENA_IO_RXQ_IDX(val));
> if (unlikely(rc && (rc != ENA_COM_UNSUPPORTED))) {
> - RTE_LOG(ERR, PMD, "Cannot fill indirect table\n");
> + PMD_DRV_LOG(ERR, "Cannot fill indirect table\n");
> goto err_fill_indir;
> }
> }
> @@ -627,22 +640,22 @@ static int ena_rss_init_default(struct ena_adapter *adapter)
> rc = ena_com_fill_hash_function(ena_dev, ENA_ADMIN_CRC32, NULL,
> ENA_HASH_KEY_SIZE, 0xFFFFFFFF);
> if (unlikely(rc && (rc != ENA_COM_UNSUPPORTED))) {
> - RTE_LOG(INFO, PMD, "Cannot fill hash function\n");
> + PMD_DRV_LOG(INFO, "Cannot fill hash function\n");
> goto err_fill_indir;
> }
>
> rc = ena_com_set_default_hash_ctrl(ena_dev);
> if (unlikely(rc && (rc != ENA_COM_UNSUPPORTED))) {
> - RTE_LOG(INFO, PMD, "Cannot fill hash control\n");
> + PMD_DRV_LOG(INFO, "Cannot fill hash control\n");
> goto err_fill_indir;
> }
>
> rc = ena_com_indirect_table_set(ena_dev);
> if (unlikely(rc && (rc != ENA_COM_UNSUPPORTED))) {
> - RTE_LOG(ERR, PMD, "Cannot flush the indirect table\n");
> + PMD_DRV_LOG(ERR, "Cannot flush the indirect table\n");
> goto err_fill_indir;
> }
> - RTE_LOG(DEBUG, PMD, "RSS configured for port %d\n",
> + PMD_DRV_LOG(DEBUG, "RSS configured for port %d\n",
> adapter->rte_dev->data->port_id);
>
> return 0;
> @@ -693,7 +706,7 @@ static void ena_rx_queue_release(void *queue)
>
> ring->configured = 0;
>
> - RTE_LOG(NOTICE, PMD, "RX Queue %d:%d released\n",
> + PMD_DRV_LOG(NOTICE, "RX Queue %d:%d released\n",
> ring->port_id, ring->id);
> }
>
> @@ -717,7 +730,7 @@ static void ena_tx_queue_release(void *queue)
>
> ring->configured = 0;
>
> - RTE_LOG(NOTICE, PMD, "TX Queue %d:%d released\n",
> + PMD_DRV_LOG(NOTICE, "TX Queue %d:%d released\n",
> ring->port_id, ring->id);
> }
>
> @@ -929,7 +942,7 @@ static int ena_stats_get(struct rte_eth_dev *dev,
> memset(&ena_stats, 0, sizeof(ena_stats));
> rc = ena_com_get_dev_basic_stats(ena_dev, &ena_stats);
> if (unlikely(rc)) {
> - RTE_LOG(ERR, PMD, "Could not retrieve statistics from ENA\n");
> + PMD_DRV_LOG(ERR, "Could not retrieve statistics from ENA\n");
> return rc;
> }
>
> @@ -986,7 +999,7 @@ static int ena_mtu_set(struct rte_eth_dev *dev, uint16_t mtu)
> ena_assert_msg(ena_dev != NULL, "Uninitialized device\n");
>
> if (mtu > ena_get_mtu_conf(adapter) || mtu < ENA_MIN_MTU) {
> - RTE_LOG(ERR, PMD,
> + PMD_DRV_LOG(ERR,
> "Invalid MTU setting. new_mtu: %d "
> "max mtu: %d min mtu: %d\n",
> mtu, ena_get_mtu_conf(adapter), ENA_MIN_MTU);
> @@ -995,9 +1008,9 @@ static int ena_mtu_set(struct rte_eth_dev *dev, uint16_t mtu)
>
> rc = ena_com_set_dev_mtu(ena_dev, mtu);
> if (rc)
> - RTE_LOG(ERR, PMD, "Could not set MTU: %d\n", mtu);
> + PMD_DRV_LOG(ERR, "Could not set MTU: %d\n", mtu);
> else
> - RTE_LOG(NOTICE, PMD, "Set MTU: %d\n", mtu);
> + PMD_DRV_LOG(NOTICE, "Set MTU: %d\n", mtu);
>
> return rc;
> }
> @@ -1061,7 +1074,7 @@ static void ena_stop(struct rte_eth_dev *dev)
> if (adapter->trigger_reset) {
> rc = ena_com_dev_reset(ena_dev, adapter->reset_reason);
> if (rc)
> - RTE_LOG(ERR, PMD, "Device reset failed rc=%d\n", rc);
> + PMD_DRV_LOG(ERR, "Device reset failed rc=%d\n", rc);
> }
>
> ++adapter->dev_stats.dev_stop;
> @@ -1103,7 +1116,7 @@ static int ena_create_io_queue(struct ena_ring *ring)
>
> rc = ena_com_create_io_queue(ena_dev, &ctx);
> if (rc) {
> - RTE_LOG(ERR, PMD,
> + PMD_DRV_LOG(ERR,
> "failed to create io queue #%d (qid:%d) rc: %d\n",
> ring->id, ena_qid, rc);
> return rc;
> @@ -1113,7 +1126,7 @@ static int ena_create_io_queue(struct ena_ring *ring)
> &ring->ena_com_io_sq,
> &ring->ena_com_io_cq);
> if (rc) {
> - RTE_LOG(ERR, PMD,
> + PMD_DRV_LOG(ERR,
> "Failed to get io queue handlers. queue num %d rc: %d\n",
> ring->id, rc);
> ena_com_destroy_io_queue(ena_dev, ena_qid);
> @@ -1206,21 +1219,21 @@ static int ena_tx_queue_setup(struct rte_eth_dev *dev,
> txq = &adapter->tx_ring[queue_idx];
>
> if (txq->configured) {
> - RTE_LOG(CRIT, PMD,
> + PMD_DRV_LOG(CRIT,
> "API violation. Queue %d is already configured\n",
> queue_idx);
> return ENA_COM_FAULT;
> }
>
> if (!rte_is_power_of_2(nb_desc)) {
> - RTE_LOG(ERR, PMD,
> + PMD_DRV_LOG(ERR,
> "Unsupported size of TX queue: %d is not a power of 2.\n",
> nb_desc);
> return -EINVAL;
> }
>
> if (nb_desc > adapter->tx_ring_size) {
> - RTE_LOG(ERR, PMD,
> + PMD_DRV_LOG(ERR,
> "Unsupported size of TX queue (max size: %d)\n",
> adapter->tx_ring_size);
> return -EINVAL;
> @@ -1240,7 +1253,7 @@ static int ena_tx_queue_setup(struct rte_eth_dev *dev,
> txq->ring_size,
> RTE_CACHE_LINE_SIZE);
> if (!txq->tx_buffer_info) {
> - RTE_LOG(ERR, PMD, "failed to alloc mem for tx buffer info\n");
> + PMD_DRV_LOG(ERR, "failed to alloc mem for tx buffer info\n");
> return -ENOMEM;
> }
>
> @@ -1248,7 +1261,7 @@ static int ena_tx_queue_setup(struct rte_eth_dev *dev,
> sizeof(u16) * txq->ring_size,
> RTE_CACHE_LINE_SIZE);
> if (!txq->empty_tx_reqs) {
> - RTE_LOG(ERR, PMD, "failed to alloc mem for tx reqs\n");
> + PMD_DRV_LOG(ERR, "failed to alloc mem for tx reqs\n");
> rte_free(txq->tx_buffer_info);
> return -ENOMEM;
> }
> @@ -1258,7 +1271,7 @@ static int ena_tx_queue_setup(struct rte_eth_dev *dev,
> txq->tx_max_header_size,
> RTE_CACHE_LINE_SIZE);
> if (!txq->push_buf_intermediate_buf) {
> - RTE_LOG(ERR, PMD, "failed to alloc push buff for LLQ\n");
> + PMD_DRV_LOG(ERR, "failed to alloc push buff for LLQ\n");
> rte_free(txq->tx_buffer_info);
> rte_free(txq->empty_tx_reqs);
> return -ENOMEM;
> @@ -1291,7 +1304,7 @@ static int ena_rx_queue_setup(struct rte_eth_dev *dev,
>
> rxq = &adapter->rx_ring[queue_idx];
> if (rxq->configured) {
> - RTE_LOG(CRIT, PMD,
> + PMD_DRV_LOG(CRIT,
> "API violation. Queue %d is already configured\n",
> queue_idx);
> return ENA_COM_FAULT;
> @@ -1301,14 +1314,14 @@ static int ena_rx_queue_setup(struct rte_eth_dev *dev,
> nb_desc = adapter->rx_ring_size;
>
> if (!rte_is_power_of_2(nb_desc)) {
> - RTE_LOG(ERR, PMD,
> + PMD_DRV_LOG(ERR,
> "Unsupported size of RX queue: %d is not a power of 2.\n",
> nb_desc);
> return -EINVAL;
> }
>
> if (nb_desc > adapter->rx_ring_size) {
> - RTE_LOG(ERR, PMD,
> + PMD_DRV_LOG(ERR,
> "Unsupported size of RX queue (max size: %d)\n",
> adapter->rx_ring_size);
> return -EINVAL;
> @@ -1325,7 +1338,7 @@ static int ena_rx_queue_setup(struct rte_eth_dev *dev,
> sizeof(struct rte_mbuf *) * nb_desc,
> RTE_CACHE_LINE_SIZE);
> if (!rxq->rx_buffer_info) {
> - RTE_LOG(ERR, PMD, "failed to alloc mem for rx buffer info\n");
> + PMD_DRV_LOG(ERR, "failed to alloc mem for rx buffer info\n");
> return -ENOMEM;
> }
>
> @@ -1334,7 +1347,7 @@ static int ena_rx_queue_setup(struct rte_eth_dev *dev,
> RTE_CACHE_LINE_SIZE);
>
> if (!rxq->rx_refill_buffer) {
> - RTE_LOG(ERR, PMD, "failed to alloc mem for rx refill buffer\n");
> + PMD_DRV_LOG(ERR, "failed to alloc mem for rx refill buffer\n");
> rte_free(rxq->rx_buffer_info);
> rxq->rx_buffer_info = NULL;
> return -ENOMEM;
> @@ -1344,7 +1357,7 @@ static int ena_rx_queue_setup(struct rte_eth_dev *dev,
> sizeof(uint16_t) * nb_desc,
> RTE_CACHE_LINE_SIZE);
> if (!rxq->empty_rx_reqs) {
> - RTE_LOG(ERR, PMD, "failed to alloc mem for empty rx reqs\n");
> + PMD_DRV_LOG(ERR, "failed to alloc mem for empty rx reqs\n");
> rte_free(rxq->rx_buffer_info);
> rxq->rx_buffer_info = NULL;
> rte_free(rxq->rx_refill_buffer);
> @@ -1408,7 +1421,7 @@ static int ena_populate_rx_queue(struct ena_ring *rxq, unsigned int count)
> rc = ena_com_add_single_rx_desc(rxq->ena_com_io_sq,
> &ebuf, req_id);
> if (unlikely(rc)) {
> - RTE_LOG(WARNING, PMD, "failed adding rx desc\n");
> + PMD_DRV_LOG(WARNING, "failed adding rx desc\n");
> rxq->rx_buffer_info[req_id] = NULL;
> break;
> }
> @@ -1416,7 +1429,7 @@ static int ena_populate_rx_queue(struct ena_ring *rxq, unsigned int count)
> }
>
> if (unlikely(i < count)) {
> - RTE_LOG(WARNING, PMD, "refilled rx qid %d with only %d "
> + PMD_DRV_LOG(WARNING, "refilled rx qid %d with only %d "
> "buffers (from %d)\n", rxq->id, i, count);
> rte_mempool_put_bulk(rxq->mb_pool, (void **)(&mbufs[i]),
> count - i);
> @@ -1450,7 +1463,7 @@ static int ena_device_init(struct ena_com_dev *ena_dev,
> /* Initialize mmio registers */
> rc = ena_com_mmio_reg_read_request_init(ena_dev);
> if (rc) {
> - RTE_LOG(ERR, PMD, "failed to init mmio read less\n");
> + PMD_DRV_LOG(ERR, "failed to init mmio read less\n");
> return rc;
> }
>
> @@ -1465,14 +1478,14 @@ static int ena_device_init(struct ena_com_dev *ena_dev,
> /* reset device */
> rc = ena_com_dev_reset(ena_dev, ENA_REGS_RESET_NORMAL);
> if (rc) {
> - RTE_LOG(ERR, PMD, "cannot reset device\n");
> + PMD_DRV_LOG(ERR, "cannot reset device\n");
> goto err_mmio_read_less;
> }
>
> /* check FW version */
> rc = ena_com_validate_version(ena_dev);
> if (rc) {
> - RTE_LOG(ERR, PMD, "device version is too low\n");
> + PMD_DRV_LOG(ERR, "device version is too low\n");
> goto err_mmio_read_less;
> }
>
> @@ -1481,7 +1494,7 @@ static int ena_device_init(struct ena_com_dev *ena_dev,
> /* ENA device administration layer init */
> rc = ena_com_admin_init(ena_dev, &aenq_handlers);
> if (rc) {
> - RTE_LOG(ERR, PMD,
> + PMD_DRV_LOG(ERR,
> "cannot initialize ena admin queue with device\n");
> goto err_mmio_read_less;
> }
> @@ -1497,7 +1510,7 @@ static int ena_device_init(struct ena_com_dev *ena_dev,
> /* Get Device Attributes and features */
> rc = ena_com_get_dev_attr_feat(ena_dev, get_feat_ctx);
> if (rc) {
> - RTE_LOG(ERR, PMD,
> + PMD_DRV_LOG(ERR,
> "cannot get attribute for ena device rc= %d\n", rc);
> goto err_admin_init;
> }
> @@ -1511,7 +1524,7 @@ static int ena_device_init(struct ena_com_dev *ena_dev,
> aenq_groups &= get_feat_ctx->aenq.supported_groups;
> rc = ena_com_set_aenq_config(ena_dev, aenq_groups);
> if (rc) {
> - RTE_LOG(ERR, PMD, "Cannot configure aenq groups rc: %d\n", rc);
> + PMD_DRV_LOG(ERR, "Cannot configure aenq groups rc: %d\n", rc);
> goto err_admin_init;
> }
>
> @@ -1548,7 +1561,7 @@ static void check_for_missing_keep_alive(struct ena_adapter *adapter)
>
> if (unlikely((rte_get_timer_cycles() - adapter->timestamp_wd) >=
> adapter->keep_alive_timeout)) {
> - RTE_LOG(ERR, PMD, "Keep alive timeout\n");
> + PMD_DRV_LOG(ERR, "Keep alive timeout\n");
> adapter->reset_reason = ENA_REGS_RESET_KEEP_ALIVE_TO;
> adapter->trigger_reset = true;
> ++adapter->dev_stats.wd_expired;
> @@ -1559,7 +1572,7 @@ static void check_for_missing_keep_alive(struct ena_adapter *adapter)
> static void check_for_admin_com_state(struct ena_adapter *adapter)
> {
> if (unlikely(!ena_com_get_admin_running_state(&adapter->ena_dev))) {
> - RTE_LOG(ERR, PMD, "ENA admin queue is not in running state!\n");
> + PMD_DRV_LOG(ERR, "ENA admin queue is not in running state!\n");
> adapter->reset_reason = ENA_REGS_RESET_ADMIN_TO;
> adapter->trigger_reset = true;
> }
> @@ -1575,7 +1588,7 @@ static void ena_timer_wd_callback(__rte_unused struct rte_timer *timer,
> check_for_admin_com_state(adapter);
>
> if (unlikely(adapter->trigger_reset)) {
> - RTE_LOG(ERR, PMD, "Trigger reset is on\n");
> + PMD_DRV_LOG(ERR, "Trigger reset is on\n");
> _rte_eth_dev_callback_process(dev, RTE_ETH_EVENT_INTR_RESET,
> NULL);
> }
> @@ -1603,7 +1616,7 @@ ena_set_queues_placement_policy(struct ena_adapter *adapter,
>
> llq_feature_mask = 1 << ENA_ADMIN_LLQ;
> if (!(ena_dev->supported_features & llq_feature_mask)) {
> - RTE_LOG(INFO, PMD,
> + PMD_DRV_LOG(INFO,
> "LLQ is not supported. Fallback to host mode policy.\n");
> ena_dev->tx_mem_queue_type = ENA_ADMIN_PLACEMENT_POLICY_HOST;
> return 0;
> @@ -1622,7 +1635,7 @@ ena_set_queues_placement_policy(struct ena_adapter *adapter,
> return 0;
>
> if (!adapter->dev_mem_base) {
> - RTE_LOG(ERR, PMD, "Unable to access LLQ bar resource. "
> + PMD_DRV_LOG(ERR, "Unable to access LLQ bar resource. "
> "Fallback to host mode policy.\n.");
> ena_dev->tx_mem_queue_type = ENA_ADMIN_PLACEMENT_POLICY_HOST;
> return 0;
> @@ -1663,7 +1676,7 @@ static int ena_calc_io_queue_num(struct ena_com_dev *ena_dev,
> io_queue_num = RTE_MIN(io_queue_num, io_tx_cq_num);
>
> if (unlikely(io_queue_num == 0)) {
> - RTE_LOG(ERR, PMD, "Number of IO queues should not be 0\n");
> + PMD_DRV_LOG(ERR, "Number of IO queues should not be 0\n");
> return -EFAULT;
> }
>
> @@ -1747,7 +1760,7 @@ static int eth_ena_dev_init(struct rte_eth_dev *eth_dev)
> queue_type_str = "Regular";
> else
> queue_type_str = "Low latency";
> - RTE_LOG(INFO, PMD, "Placement policy: %s\n", queue_type_str);
> + PMD_DRV_LOG(INFO, "Placement policy: %s\n", queue_type_str);
>
> calc_queue_ctx.ena_dev = ena_dev;
> calc_queue_ctx.get_feat_ctx = &get_feat_ctx;
> @@ -1799,7 +1812,7 @@ static int eth_ena_dev_init(struct rte_eth_dev *eth_dev)
> sizeof(*adapter->drv_stats),
> RTE_CACHE_LINE_SIZE);
> if (!adapter->drv_stats) {
> - RTE_LOG(ERR, PMD, "failed to alloc mem for adapter stats\n");
> + PMD_DRV_LOG(ERR, "failed to alloc mem for adapter stats\n");
> rc = -ENOMEM;
> goto err_delete_debug_area;
> }
> @@ -2004,7 +2017,7 @@ static uint16_t eth_ena_recv_pkts(void *rx_queue, struct rte_mbuf **rx_pkts,
>
> /* Check adapter state */
> if (unlikely(rx_ring->adapter->state != ENA_ADAPTER_STATE_RUNNING)) {
> - RTE_LOG(ALERT, PMD,
> + PMD_DRV_LOG(ALERT,
> "Trying to receive pkts while device is NOT running\n");
> return 0;
> }
> @@ -2024,7 +2037,7 @@ static uint16_t eth_ena_recv_pkts(void *rx_queue, struct rte_mbuf **rx_pkts,
> rx_ring->ena_com_io_sq,
> &ena_rx_ctx);
> if (unlikely(rc)) {
> - RTE_LOG(ERR, PMD, "ena_com_rx_pkt error %d\n", rc);
> + PMD_DRV_LOG(ERR, "ena_com_rx_pkt error %d\n", rc);
> rx_ring->adapter->reset_reason =
> ENA_REGS_RESET_TOO_MANY_RX_DESCS;
> rx_ring->adapter->trigger_reset = true;
> @@ -2214,7 +2227,7 @@ static int ena_check_and_linearize_mbuf(struct ena_ring *tx_ring,
> ++tx_ring->tx_stats.linearize;
> rc = rte_pktmbuf_linearize(mbuf);
> if (unlikely(rc)) {
> - RTE_LOG(WARNING, PMD, "Mbuf linearize failed\n");
> + PMD_DRV_LOG(WARNING, "Mbuf linearize failed\n");
> rte_atomic64_inc(&tx_ring->adapter->drv_stats->ierrors);
> ++tx_ring->tx_stats.linearize_failed;
> return rc;
> @@ -2245,7 +2258,7 @@ static uint16_t eth_ena_xmit_pkts(void *tx_queue, struct rte_mbuf **tx_pkts,
>
> /* Check adapter state */
> if (unlikely(tx_ring->adapter->state != ENA_ADAPTER_STATE_RUNNING)) {
> - RTE_LOG(ALERT, PMD,
> + PMD_DRV_LOG(ALERT,
> "Trying to xmit pkts while device is NOT running\n");
> return 0;
> }
> @@ -2342,7 +2355,7 @@ static uint16_t eth_ena_xmit_pkts(void *tx_queue, struct rte_mbuf **tx_pkts,
>
> if (ena_com_is_doorbell_needed(tx_ring->ena_com_io_sq,
> &ena_tx_ctx)) {
> - RTE_LOG(DEBUG, PMD, "llq tx max burst size of queue %d"
> + PMD_DRV_LOG(DEBUG, "llq tx max burst size of queue %d"
> " achieved, writing doorbell to send burst\n",
> tx_ring->id);
> rte_wmb();
> @@ -2601,6 +2614,30 @@ RTE_INIT(ena_init_log)
> ena_logtype_driver = rte_log_register("pmd.net.ena.driver");
> if (ena_logtype_driver >= 0)
> rte_log_set_level(ena_logtype_driver, RTE_LOG_NOTICE);
> +
> +#ifdef RTE_LIBRTE_ENA_DEBUG_RX
> + ena_logtype_rx = rte_log_register("pmd.net.ena.rx");
> + if (ena_logtype_rx >= 0)
> + rte_log_set_level(ena_logtype_rx, RTE_LOG_NOTICE);
> +#endif
> +
> +#ifdef RTE_LIBRTE_ENA_DEBUG_TX
> + ena_logtype_tx = rte_log_register("pmd.net.ena.tx");
> + if (ena_logtype_tx >= 0)
> + rte_log_set_level(ena_logtype_tx, RTE_LOG_NOTICE);
> +#endif
> +
> +#ifdef RTE_LIBRTE_ENA_DEBUG_TX_FREE
> + ena_logtype_tx_free = rte_log_register("pmd.net.ena.tx_free");
> + if (ena_logtype_tx_free >= 0)
> + rte_log_set_level(ena_logtype_tx_free, RTE_LOG_NOTICE);
> +#endif
> +
> +#ifdef RTE_LIBRTE_ENA_COM_DEBUG
> + ena_logtype_com = rte_log_register("pmd.net.ena.com");
> + if (ena_logtype_com >= 0)
> + rte_log_set_level(ena_logtype_com, RTE_LOG_NOTICE);
> +#endif
> }
>
> /******************************************************************************
> @@ -2632,7 +2669,7 @@ static void ena_notification(void *data,
> struct ena_admin_ena_hw_hints *hints;
>
> if (aenq_e->aenq_common_desc.group != ENA_ADMIN_NOTIFICATION)
> - RTE_LOG(WARNING, PMD, "Invalid group(%x) expected %x\n",
> + PMD_DRV_LOG(WARNING, "Invalid group(%x) expected %x\n",
> aenq_e->aenq_common_desc.group,
> ENA_ADMIN_NOTIFICATION);
>
> @@ -2643,7 +2680,7 @@ static void ena_notification(void *data,
> ena_update_hints(adapter, hints);
> break;
> default:
> - RTE_LOG(ERR, PMD, "Invalid aenq notification link state %d\n",
> + PMD_DRV_LOG(ERR, "Invalid aenq notification link state %d\n",
> aenq_e->aenq_common_desc.syndrom);
> }
> }
> @@ -2668,7 +2705,7 @@ static void ena_keep_alive(void *adapter_data,
> static void unimplemented_aenq_handler(__rte_unused void *data,
> __rte_unused struct ena_admin_aenq_entry *aenq_e)
> {
> - RTE_LOG(ERR, PMD, "Unknown event was received or event with "
> + PMD_DRV_LOG(ERR, "Unknown event was received or event with "
> "unimplemented handler\n");
> }
>
> diff --git a/drivers/net/ena/ena_logs.h b/drivers/net/ena/ena_logs.h
> index 2c0e91b656ac..fb7fb1fc143b 100644
> --- a/drivers/net/ena/ena_logs.h
> +++ b/drivers/net/ena/ena_logs.h
> @@ -40,22 +40,28 @@ extern int ena_logtype_init;
> "%s(): " fmt "\n", __func__, ## args)
>
> #ifdef RTE_LIBRTE_ENA_DEBUG_RX
> -#define PMD_RX_LOG(level, fmt, args...) \
> - RTE_LOG(level, PMD, "%s(): " fmt "\n", __func__, ## args)
> +extern int ena_logtype_rx;
> +#define PMD_RX_LOG(level, fmt, args...) \
> + rte_log(RTE_LOG_ ## level, ena_logtype_rx, \
> + "%s(): " fmt "\n", __func__, ## args)
> #else
> #define PMD_RX_LOG(level, fmt, args...) do { } while (0)
> #endif
>
> #ifdef RTE_LIBRTE_ENA_DEBUG_TX
> -#define PMD_TX_LOG(level, fmt, args...) \
> - RTE_LOG(level, PMD, "%s(): " fmt "\n", __func__, ## args)
> +extern int ena_logtype_tx;
> +#define PMD_TX_LOG(level, fmt, args...) \
> + rte_log(RTE_LOG_ ## level, ena_logtype_tx, \
> + "%s(): " fmt "\n", __func__, ## args)
> #else
> #define PMD_TX_LOG(level, fmt, args...) do { } while (0)
> #endif
>
> #ifdef RTE_LIBRTE_ENA_DEBUG_TX_FREE
> -#define PMD_TX_FREE_LOG(level, fmt, args...) \
> - RTE_LOG(level, PMD, "%s(): " fmt "\n", __func__, ## args)
> +extern int ena_logtype_tx_free;
> +#define PMD_TX_FREE_LOG(level, fmt, args...) \
> + rte_log(RTE_LOG_ ## level, ena_logtype_tx_free, \
> + "%s(): " fmt "\n", __func__, ## args)
> #else
> #define PMD_TX_FREE_LOG(level, fmt, args...) do { } while (0)
> #endif
> --
> 2.20.1
>
More information about the dev
mailing list