Hi Thomas, > -----Original Message----- > From: Thomas Monjalon <tho...@monjalon.net> > Sent: Wednesday, October 14, 2020 10:36 PM > To: Bing Zhao <bi...@nvidia.com> > Cc: Ori Kam <or...@nvidia.com>; ferruh.yi...@intel.com; > arybche...@solarflare.com; m...@ashroe.eu; nhor...@tuxdriver.com; > bernard.iremon...@intel.com; beilei.x...@intel.com; > wenzhuo...@intel.com; dev@dpdk.org > Subject: Re: [dpdk-dev] [PATCH v3 1/6] ethdev: add hairpin bind and > unbind APIs > > External email: Use caution opening links or attachments > > > Hi, > Cosmetic comments below: > > 08/10/2020 14:05, Bing Zhao: > > +int > > +rte_eth_hairpin_bind(uint16_t tx_port, uint16_t rx_port) { > > + struct rte_eth_dev *dev; > > + int ret; > > + > > + RTE_ETH_VALID_PORTID_OR_ERR_RET(tx_port, -EINVAL); > > It should be -ENODEV
Got it, changed. BTW, I checked the ethdev and it seems some functions are using "EINVAL" and some are using "ENODEV". So should all of these functions use "ENODEV"? > > > + dev = &rte_eth_devices[tx_port]; > > + if (!dev->data->dev_started) { > > + RTE_ETHDEV_LOG(ERR, "TX port %d is not started", > tx_port); > > + return -EBUSY; > > + } > > + > > + RTE_FUNC_PTR_OR_ERR_RET(*dev->dev_ops->hairpin_bind, - > ENOTSUP); > > + ret = (*dev->dev_ops->hairpin_bind)(dev, rx_port); > > + if (ret) > > + RTE_ETHDEV_LOG(ERR, "Failed to bind hairpin TX %d " > > + "to RX %d (%d - all ports)", tx_port, > > + rx_port, RTE_MAX_ETHPORTS); > > Looks like \n is missing. Fixed, thanks. > > > + > > + return ret; > > +} > > + > > +int > > +rte_eth_hairpin_unbind(uint16_t tx_port, uint16_t rx_port) > > Same comments as for bind function. Done. > > [...] > > /** > > + * @warning > > + * @b EXPERIMENTAL: this API may change, or be removed, without > prior > > + notice > > + * > > + * Bind all hairpin TX queues of one port to the RX queues of the > peer port. > > + * It is only allowed to call this API after all hairpin queues > are > > + configured > > + * properly and the devices of TX and peer RX are in started > state. > > "call this API" -> "call this function" Done. > > "devices of TX" is a strange wording. > I would make it simpler: > "the devices of TX and peer RX" -> "the devices" > > > + * > > + * @param tx_port > > + * The TX port identifier of the Ethernet device. > > A device does not have a TX port. > I think you mean "The identifier of the TX port." Done. > > > + * @param rx_port > > + * The peer RX port identifier of the Ethernet device. > > Remove "of the Ethernet device" Done. > > > + * RTE_MAX_ETHPORTS is allowed for the traversal of all devices. > > + * RX port ID could have the same value with TX port ID. > > "same value as" Done. > > > + * > > + * @return > > + * - (0) if successful. > > + * - (-EINVAL) if bad parameter. > > + * - (-EBUSY) if device is not in started state. > > + * - (-ENOTSUP) if hardware doesn't support. > > + * - Others detailed errors from PMD drivers. > > Please add ENODEV case, maybe instead of EINVAL. Replaced. PMD may return -EINVAL but it is not necessary so I will not list it here anymore. > > > + */ > > +__rte_experimental > > +int rte_eth_hairpin_bind(uint16_t tx_port, uint16_t rx_port); > > + > > +/** > > + * @warning > > + * @b EXPERIMENTAL: this API may change, or be removed, without > prior > > +notice > > + * > > + * Unbind all hairpin TX queues of one port from the RX queues of > the peer port. > > + * This should be called before closing the TX or RX devices > > +(optional). After > > Split the line after the end of sentence and start next one on a > fresh line. > Done > > + * unbind the hairpin ports pair, it is allowed to bind them > again. > > "unbind" -> "unbinding" Done > > > + * Changing queues configuration should be after stopping the > device. > > + * > > + * @param tx_port > > + * The TX port identifier of the Ethernet device. > > + * @param rx_port > > + * The peer RX port identifier of the Ethernet device. > > + * RTE_MAX_ETHPORTS is allowed for traversal of all devices. > > + * RX port ID could have the same value with TX port ID. > > + * > > + * @return > > + * - (0) if successful. > > + * - (-EINVAL) if bad parameter. > > + * - (-EBUSY) if device is in stopped state. > > + * - (-ENOTSUP) if hardware doesn't support. > > + * - Others detailed errors from PMD drivers. > > Same comments as for the bind function. Done. > > > + */ > > +__rte_experimental > > +int rte_eth_hairpin_unbind(uint16_t tx_port, uint16_t rx_port); > > Thanks a lot