From: "Qiu, Michael" <michael.qiu@intel.com>
To: "Chen, Jing D" <jing.d.chen@intel.com>, "dev@dpdk.org" <dev@dpdk.org>
Subject: Re: [dpdk-dev] [PATCH 10/18] fm10k: add dev start/stop functions
Date: Wed, 4 Feb 2015 02:36:19 +0000 [thread overview]
Message-ID: <533710CFB86FA344BFBF2D6802E60286CD4285@SHSMSX101.ccr.corp.intel.com> (raw)
In-Reply-To: <1422594454-11045-11-git-send-email-jing.d.chen@intel.com>
On 1/30/2015 1:08 PM, Chen, Jing D wrote:
> From: Jeff Shaw <jeffrey.b.shaw@intel.com>
>
> 1. Add function to initialize single RX queue.
> 2. Add function to initialize single TX queue.
> 3. Add fm10k_dev_start, fm10k_dev_stop and fm10k_dev_close
> functions.
>
> Signed-off-by: Jeff Shaw <jeffrey.b.shaw@intel.com>
> Signed-off-by: Chen Jing D(Mark) <jing.d.chen@intel.com>
> ---
> lib/librte_pmd_fm10k/fm10k_ethdev.c | 220 +++++++++++++++++++++++++++++++++++
> 1 files changed, 220 insertions(+), 0 deletions(-)
>
> diff --git a/lib/librte_pmd_fm10k/fm10k_ethdev.c b/lib/librte_pmd_fm10k/fm10k_ethdev.c
> index b4b49cd..3cf5e25 100644
> --- a/lib/librte_pmd_fm10k/fm10k_ethdev.c
> +++ b/lib/librte_pmd_fm10k/fm10k_ethdev.c
> @@ -49,6 +49,8 @@
> #define CHARS_PER_UINT32 (sizeof(uint32_t))
> #define BIT_MASK_PER_UINT32 ((1 << CHARS_PER_UINT32) - 1)
>
> +static void fm10k_close_mbx_service(struct fm10k_hw *hw);
> +
> static void
> fm10k_mbx_initlock(struct fm10k_hw *hw)
> {
> @@ -268,6 +270,98 @@ fm10k_dev_configure(struct rte_eth_dev *dev)
> }
>
> static int
> +fm10k_dev_tx_init(struct rte_eth_dev *dev)
> +{
> + struct fm10k_hw *hw = FM10K_DEV_PRIVATE_TO_HW(dev->data->dev_private);
> + int i, ret;
> + struct fm10k_tx_queue *txq;
> + uint64_t base_addr;
> + uint32_t size;
> +
> + /* Disable TXINT to avoid possible interrupt */
> + for (i = 0; i < hw->mac.max_queues; i++)
> + FM10K_WRITE_REG(hw, FM10K_TXINT(i),
> + 3 << FM10K_TXINT_TIMER_SHIFT);
> +
> + /* Setup TX queue */
> + for (i = 0; i < dev->data->nb_tx_queues; ++i) {
> + txq = dev->data->tx_queues[i];
> + base_addr = txq->hw_ring_phys_addr;
> + size = txq->nb_desc * sizeof(struct fm10k_tx_desc);
> +
> + /* disable queue to avoid issues while updating state */
> + ret = tx_queue_disable(hw, i);
> + if (ret) {
> + PMD_LOG(ERR, "failed to disable queue %d\n", i);
> + return -1;
> + }
> +
> + /* set location and size for descriptor ring */
> + FM10K_WRITE_REG(hw, FM10K_TDBAL(i),
> + base_addr & 0x00000000ffffffffULL);
Here better to make a address mask here.
> + FM10K_WRITE_REG(hw, FM10K_TDBAH(i),
> + base_addr >> (CHAR_BIT * sizeof(uint32_t)));
> + FM10K_WRITE_REG(hw, FM10K_TDLEN(i), size);
> + }
> + return 0;
> +}
> +
> +static int
> +fm10k_dev_rx_init(struct rte_eth_dev *dev)
> +{
> + struct fm10k_hw *hw = FM10K_DEV_PRIVATE_TO_HW(dev->data->dev_private);
> + int i, ret;
> + struct fm10k_rx_queue *rxq;
> + uint64_t base_addr;
> + uint32_t size;
> + uint32_t rxdctl = FM10K_RXDCTL_WRITE_BACK_MIN_DELAY;
> + uint16_t buf_size;
> + struct rte_pktmbuf_pool_private *mbp_priv;
> +
> + /* Disable RXINT to avoid possible interrupt */
> + for (i = 0; i < hw->mac.max_queues; i++)
> + FM10K_WRITE_REG(hw, FM10K_RXINT(i),
> + 3 << FM10K_RXINT_TIMER_SHIFT);
> +
> + /* Setup RX queues */
> + for (i = 0; i < dev->data->nb_rx_queues; ++i) {
> + rxq = dev->data->rx_queues[i];
> + base_addr = rxq->hw_ring_phys_addr;
> + size = rxq->nb_desc * sizeof(union fm10k_rx_desc);
> +
> + /* disable queue to avoid issues while updating state */
> + ret = rx_queue_disable(hw, i);
> + if (ret) {
> + PMD_LOG(ERR, "failed to disable queue %d\n", i);
> + return -1;
> + }
> +
> + /* Setup the Base and Length of the Rx Descriptor Ring */
> + FM10K_WRITE_REG(hw, FM10K_RDBAL(i),
> + base_addr & 0x00000000ffffffffULL);
Here better to make a address mask here.
Thanks,
Michael
> + FM10K_WRITE_REG(hw, FM10K_RDBAH(i),
> + base_addr >> (CHAR_BIT * sizeof(uint32_t)));
> + FM10K_WRITE_REG(hw, FM10K_RDLEN(i), size);
> +
> + /* Configure the Rx buffer size for one buff without split */
> + mbp_priv = rte_mempool_get_priv(rxq->mp);
> + buf_size = (uint16_t) (mbp_priv->mbuf_data_room_size -
> + RTE_PKTMBUF_HEADROOM);
> + FM10K_WRITE_REG(hw, FM10K_SRRCTL(i),
> + buf_size >> FM10K_SRRCTL_BSIZEPKT_SHIFT);
> +
> + /* Enable drop on empty, it's RO for VF */
> + if (hw->mac.type == fm10k_mac_pf && rxq->drop_en)
> + rxdctl |= FM10K_RXDCTL_DROP_ON_EMPTY;
> +
> + FM10K_WRITE_REG(hw, FM10K_RXDCTL(i), rxdctl);
> + FM10K_WRITE_FLUSH(hw);
> + }
> +
> + return 0;
> +}
> +
> +static int
> fm10k_dev_rx_queue_start(struct rte_eth_dev *dev, uint16_t rx_queue_id)
> {
> struct fm10k_hw *hw = FM10K_DEV_PRIVATE_TO_HW(dev->data->dev_private);
> @@ -371,6 +465,122 @@ fm10k_dev_tx_queue_stop(struct rte_eth_dev *dev, uint16_t tx_queue_id)
> return 0;
> }
>
> +/* fls = find last set bit = 32 minus the number of leading zeros */
> +#ifndef fls
> +#define fls(x) (((x) == 0) ? 0 : (32 - __builtin_clz((x))))
> +#endif
> +#define BSIZEPKT_ROUNDUP ((1 << FM10K_SRRCTL_BSIZEPKT_SHIFT) - 1)
> +static int
> +fm10k_dev_start(struct rte_eth_dev *dev)
> +{
> + struct fm10k_hw *hw = FM10K_DEV_PRIVATE_TO_HW(dev->data->dev_private);
> + int i, diag;
> +
> + PMD_FUNC_TRACE();
> +
> + /* stop, init, then start the hw */
> + diag = fm10k_stop_hw(hw);
> + if (diag != FM10K_SUCCESS) {
> + PMD_LOG(ERR, "Hardware stop failed: %d", diag);
> + return -EIO;
> + }
> +
> + diag = fm10k_init_hw(hw);
> + if (diag != FM10K_SUCCESS) {
> + PMD_LOG(ERR, "Hardware init failed: %d", diag);
> + return -EIO;
> + }
> +
> + diag = fm10k_start_hw(hw);
> + if (diag != FM10K_SUCCESS) {
> + PMD_LOG(ERR, "Hardware start failed: %d", diag);
> + return -EIO;
> + }
> +
> + diag = fm10k_dev_tx_init(dev);
> + if (diag) {
> + PMD_LOG(ERR, "TX init failed: %d", diag);
> + return diag;
> + }
> +
> + diag = fm10k_dev_rx_init(dev);
> + if (diag) {
> + PMD_LOG(ERR, "RX init failed: %d", diag);
> + return diag;
> + }
> +
> + if (hw->mac.type == fm10k_mac_pf) {
> + /* Establish only VSI 0 as valid */
> + FM10K_WRITE_REG(hw, FM10K_DGLORTMAP(0), FM10K_DGLORTMAP_ANY);
> +
> + /* Configure RSS bits used in RETA table */
> + FM10K_WRITE_REG(hw, FM10K_DGLORTDEC(0),
> + fls(dev->data->nb_rx_queues - 1) <<
> + FM10K_DGLORTDEC_RSSLENGTH_SHIFT);
> +
> + /* Invalidate all other GLORT entries */
> + for (i = 1; i < FM10K_DGLORT_COUNT; i++)
> + FM10K_WRITE_REG(hw, FM10K_DGLORTMAP(i),
> + FM10K_DGLORTMAP_NONE);
> + }
> +
> + for (i = 0; i < dev->data->nb_rx_queues; i++) {
> + struct fm10k_rx_queue *rxq;
> + rxq = dev->data->rx_queues[i];
> +
> + if (rxq->rx_deferred_start)
> + continue;
> + diag = fm10k_dev_rx_queue_start(dev, i);
> + if (diag != 0) {
> + int j;
> + for (j = 0; j < i; ++j)
> + rx_queue_clean(dev->data->rx_queues[j]);
> + return diag;
> + }
> + }
> +
> + for (i = 0; i < dev->data->nb_tx_queues; i++) {
> + struct fm10k_tx_queue *txq;
> + txq = dev->data->tx_queues[i];
> +
> + if (txq->tx_deferred_start)
> + continue;
> + diag = fm10k_dev_tx_queue_start(dev, i);
> + if (diag != 0) {
> + int j;
> + for (j = 0; j < dev->data->nb_rx_queues; ++j)
> + rx_queue_clean(dev->data->rx_queues[j]);
> + return diag;
> + }
> + }
> +
> + return 0;
> +}
> +
> +static void
> +fm10k_dev_stop(struct rte_eth_dev *dev)
> +{
> + int i;
> + PMD_FUNC_TRACE();
> +
> + for (i = 0; i < dev->data->nb_tx_queues; i++)
> + fm10k_dev_tx_queue_stop(dev, i);
> +
> + for (i = 0; i < dev->data->nb_rx_queues; i++)
> + fm10k_dev_rx_queue_stop(dev, i);
> +}
> +
> +static void
> +fm10k_dev_close(struct rte_eth_dev *dev)
> +{
> + struct fm10k_hw *hw = FM10K_DEV_PRIVATE_TO_HW(dev->data->dev_private);
> +
> + /* Stop mailbox service first */
> + fm10k_close_mbx_service(hw);
> + fm10k_dev_stop(dev);
> + fm10k_stop_hw(hw);
> +}
> +
> static int
> fm10k_link_update(struct rte_eth_dev *dev,
> __rte_unused int wait_to_complete)
> @@ -977,8 +1187,18 @@ fm10k_setup_mbx_service(struct fm10k_hw *hw)
> return hw->mbx.ops.connect(hw, &hw->mbx);
> }
>
> +static void
> +fm10k_close_mbx_service(struct fm10k_hw *hw)
> +{
> + /* Disconnect from SM for PF device or PF for VF device */
> + hw->mbx.ops.disconnect(hw, &hw->mbx);
> +}
> +
> static struct eth_dev_ops fm10k_eth_dev_ops = {
> .dev_configure = fm10k_dev_configure,
> + .dev_start = fm10k_dev_start,
> + .dev_stop = fm10k_dev_stop,
> + .dev_close = fm10k_dev_close,
> .link_update = fm10k_link_update,
> .stats_get = fm10k_stats_get,
> .stats_reset = fm10k_stats_reset,
next prev parent reply other threads:[~2015-02-04 2:36 UTC|newest]
Thread overview: 147+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-01-30 5:07 [dpdk-dev] [PATCH 00/18] lib/librte_pmd_fm10k : fm10k pmd driver Chen Jing D(Mark)
2015-01-30 5:07 ` [dpdk-dev] [PATCH 01/18] fm10k: add base driver Chen Jing D(Mark)
2015-02-04 10:40 ` [dpdk-dev] [PATCH v2 00/15] lib/librte_pmd_fm10k : fm10k pmd driver Chen Jing D(Mark)
2015-02-04 10:40 ` [dpdk-dev] [PATCH v2 01/15] fm10k: add base driver Chen Jing D(Mark)
2015-02-10 7:02 ` [dpdk-dev] [PATCH v3 00/15] lib/librte_pmd_fm10k : fm10k pmd driver Chen Jing D(Mark)
2015-02-10 7:02 ` [dpdk-dev] [PATCH v3 01/15] fm10k: add base driver Chen Jing D(Mark)
2015-02-11 1:31 ` [dpdk-dev] [PATCH v4 00/15] lib/librte_pmd_fm10k : fm10k pmd driver Chen Jing D(Mark)
2015-02-11 1:31 ` [dpdk-dev] [PATCH v4 01/15] fm10k: add base driver Chen Jing D(Mark)
2015-02-13 8:19 ` [dpdk-dev] [PATCH v5 00/17] lib/librte_pmd_fm10k : fm10k pmd driver Chen Jing D(Mark)
2015-02-13 8:19 ` [dpdk-dev] [PATCH v5 01/17] fm10k: add base driver Chen Jing D(Mark)
2015-02-17 14:18 ` [dpdk-dev] [PATCH v6 00/16] lib/librte_pmd_fm10k : fm10k pmd driver Chen Jing D(Mark)
2015-02-17 14:18 ` [dpdk-dev] [PATCH v6 01/16] fm10k: add base driver Chen Jing D(Mark)
2015-02-17 14:18 ` [dpdk-dev] [PATCH v6 02/16] eal: add fm10k device id Chen Jing D(Mark)
2015-02-17 14:18 ` [dpdk-dev] [PATCH v6 03/16] fm10k: register fm10k pmd PF driver Chen Jing D(Mark)
2015-02-17 14:18 ` [dpdk-dev] [PATCH v6 04/16] config: change config files to add fm10k into compile Chen Jing D(Mark)
2015-02-17 14:18 ` [dpdk-dev] [PATCH v6 05/16] fm10k: add reta update/requery functions Chen Jing D(Mark)
2015-02-17 14:18 ` [dpdk-dev] [PATCH v6 06/16] fm10k: add Rx queue setup/release function Chen Jing D(Mark)
2015-02-17 14:18 ` [dpdk-dev] [PATCH v6 07/16] fm10k: add Tx " Chen Jing D(Mark)
2015-02-17 14:18 ` [dpdk-dev] [PATCH v6 08/16] fm10k: add Rx/Tx single queue start/stop function Chen Jing D(Mark)
2015-02-17 14:18 ` [dpdk-dev] [PATCH v6 09/16] fm10k: add dev start/stop functions Chen Jing D(Mark)
2015-02-17 14:18 ` [dpdk-dev] [PATCH v6 10/16] fm10k: add receive and tranmit function Chen Jing D(Mark)
2015-02-17 14:18 ` [dpdk-dev] [PATCH v6 11/16] fm10k: add PF RSS support Chen Jing D(Mark)
2015-02-17 14:18 ` [dpdk-dev] [PATCH v6 12/16] fm10k: add scatter receive function Chen Jing D(Mark)
2015-02-17 14:18 ` [dpdk-dev] [PATCH v6 13/16] fm10k: add function to set vlan Chen Jing D(Mark)
2015-02-17 14:18 ` [dpdk-dev] [PATCH v6 14/16] fm10k: add SRIOV-VF support Chen Jing D(Mark)
2015-02-17 14:18 ` [dpdk-dev] [PATCH v6 15/16] fm10k: add PF and VF interrupt handling function Chen Jing D(Mark)
2015-02-17 14:18 ` [dpdk-dev] [PATCH v6 16/16] maintainers: claim for fm10k review Chen Jing D(Mark)
2015-02-18 0:13 ` [dpdk-dev] [PATCH v6 00/16] lib/librte_pmd_fm10k : fm10k pmd driver Thomas Monjalon
2015-02-13 8:19 ` [dpdk-dev] [PATCH v5 02/17] eal: add fm10k device id Chen Jing D(Mark)
2015-02-13 8:19 ` [dpdk-dev] [PATCH v5 03/17] fm10k: register fm10k pmd PF driver Chen Jing D(Mark)
2015-02-13 8:19 ` [dpdk-dev] [PATCH v5 04/17] Change config files to add fm10k into compile Chen Jing D(Mark)
2015-02-13 8:19 ` [dpdk-dev] [PATCH v5 05/17] fm10k: add reta update/requery functions Chen Jing D(Mark)
2015-02-13 8:19 ` [dpdk-dev] [PATCH v5 06/17] fm10k: add rx_queue_setup/release function Chen Jing D(Mark)
2015-02-13 11:08 ` David Marchand
2015-02-17 13:01 ` Chen, Jing D
2015-02-13 8:19 ` [dpdk-dev] [PATCH v5 07/17] fm10k: add tx_queue_setup/release function Chen Jing D(Mark)
2015-02-13 8:19 ` [dpdk-dev] [PATCH v5 08/17] fm10k: add RX/TX single queue start/stop function Chen Jing D(Mark)
2015-02-13 11:31 ` David Marchand
2015-02-13 16:45 ` Jeff Shaw
2015-02-13 8:19 ` [dpdk-dev] [PATCH v5 09/17] fm10k: add dev start/stop functions Chen Jing D(Mark)
2015-02-13 8:19 ` [dpdk-dev] [PATCH v5 10/17] fm10k: add receive and tranmit function Chen Jing D(Mark)
2015-02-13 11:42 ` David Marchand
2015-02-17 13:07 ` Chen, Jing D
2015-02-13 11:53 ` David Marchand
2015-02-17 13:10 ` Chen, Jing D
2015-02-13 8:19 ` [dpdk-dev] [PATCH v5 11/17] fm10k: add PF RSS support Chen Jing D(Mark)
2015-02-13 8:19 ` [dpdk-dev] [PATCH v5 12/17] fm10k: Add scatter receive function Chen Jing D(Mark)
2015-02-13 11:55 ` David Marchand
2015-02-17 13:11 ` Chen, Jing D
2015-02-13 8:19 ` [dpdk-dev] [PATCH v5 13/17] fm10k: add function to set vlan Chen Jing D(Mark)
2015-02-13 8:19 ` [dpdk-dev] [PATCH v5 14/17] fm10k: Add SRIOV-VF support Chen Jing D(Mark)
2015-02-13 8:19 ` [dpdk-dev] [PATCH v5 15/17] fm10k: add PF and VF interrupt handling function Chen Jing D(Mark)
2015-02-13 11:42 ` David Marchand
2015-02-17 13:12 ` Chen, Jing D
2015-02-13 8:19 ` [dpdk-dev] [PATCH v5 16/17] maintainers: claim for fm10k review Chen Jing D(Mark)
2015-02-13 8:19 ` [dpdk-dev] [PATCH v5 17/17] fm10k: Add ABI version of librte_pmd_fm10k Chen Jing D(Mark)
2015-02-13 8:37 ` [dpdk-dev] [PATCH v5 00/17] lib/librte_pmd_fm10k : fm10k pmd driver Zhang, Helin
2015-02-15 5:07 ` Qiu, Michael
2015-02-11 1:31 ` [dpdk-dev] [PATCH v4 02/15] eal: add fm10k device id Chen Jing D(Mark)
2015-02-11 1:31 ` [dpdk-dev] [PATCH v4 03/15] fm10k: register fm10k pmd PF driver Chen Jing D(Mark)
2015-02-11 1:31 ` [dpdk-dev] [PATCH v4 04/15] Change config files to add fm10k into compile Chen Jing D(Mark)
2015-02-11 1:31 ` [dpdk-dev] [PATCH v4 05/15] fm10k: add reta update/requery functions Chen Jing D(Mark)
2015-02-11 1:31 ` [dpdk-dev] [PATCH v4 06/15] fm10k: add rx_queue_setup/release function Chen Jing D(Mark)
2015-02-11 1:31 ` [dpdk-dev] [PATCH v4 07/15] fm10k: add tx_queue_setup/release function Chen Jing D(Mark)
2015-02-11 1:31 ` [dpdk-dev] [PATCH v4 08/15] fm10k: add RX/TX single queue start/stop function Chen Jing D(Mark)
2015-02-11 1:31 ` [dpdk-dev] [PATCH v4 09/15] fm10k: add dev start/stop functions Chen Jing D(Mark)
2015-02-11 1:31 ` [dpdk-dev] [PATCH v4 10/15] fm10k: add receive and tranmit function Chen Jing D(Mark)
2015-02-11 17:28 ` Jeff Shaw
2015-02-12 4:04 ` Chen, Jing D
2015-02-11 1:31 ` [dpdk-dev] [PATCH v4 11/15] fm10k: add PF RSS support Chen Jing D(Mark)
2015-02-11 1:31 ` [dpdk-dev] [PATCH v4 12/15] fm10k: Add scatter receive function Chen Jing D(Mark)
2015-02-11 17:32 ` Jeff Shaw
2015-02-12 4:04 ` Chen, Jing D
2015-02-11 1:31 ` [dpdk-dev] [PATCH v4 13/15] fm10k: add function to set vlan Chen Jing D(Mark)
2015-02-11 1:31 ` [dpdk-dev] [PATCH v4 14/15] fm10k: Add SRIOV-VF support Chen Jing D(Mark)
2015-02-11 1:31 ` [dpdk-dev] [PATCH v4 15/15] fm10k: add PF and VF interrupt handling function Chen Jing D(Mark)
2015-02-11 1:50 ` [dpdk-dev] [PATCH v4 00/15] lib/librte_pmd_fm10k : fm10k pmd driver Qiu, Michael
2015-02-10 7:02 ` [dpdk-dev] [PATCH v3 02/15] eal: add fm10k device id Chen Jing D(Mark)
2015-02-10 7:02 ` [dpdk-dev] [PATCH v3 03/15] fm10k: register fm10k pmd PF driver Chen Jing D(Mark)
2015-02-10 7:02 ` [dpdk-dev] [PATCH v3 04/15] Change config files to add fm10k into compile Chen Jing D(Mark)
2015-02-10 7:02 ` [dpdk-dev] [PATCH v3 05/15] fm10k: add reta update/requery functions Chen Jing D(Mark)
2015-02-10 7:02 ` [dpdk-dev] [PATCH v3 06/15] fm10k: add rx_queue_setup/release function Chen Jing D(Mark)
2015-02-10 7:02 ` [dpdk-dev] [PATCH v3 07/15] fm10k: add tx_queue_setup/release function Chen Jing D(Mark)
2015-02-10 7:02 ` [dpdk-dev] [PATCH v3 08/15] fm10k: add RX/TX single queue start/stop function Chen Jing D(Mark)
2015-02-10 7:02 ` [dpdk-dev] [PATCH v3 09/15] fm10k: add dev start/stop functions Chen Jing D(Mark)
2015-02-10 7:02 ` [dpdk-dev] [PATCH v3 10/15] fm10k: add receive and tranmit function Chen Jing D(Mark)
2015-02-10 7:02 ` [dpdk-dev] [PATCH v3 11/15] fm10k: add PF RSS support Chen Jing D(Mark)
2015-02-10 7:02 ` [dpdk-dev] [PATCH v3 12/15] fm10k: Add scatter receive function Chen Jing D(Mark)
2015-02-10 7:02 ` [dpdk-dev] [PATCH v3 13/15] fm10k: add function to set vlan Chen Jing D(Mark)
2015-02-10 7:02 ` [dpdk-dev] [PATCH v3 14/15] fm10k: Add SRIOV-VF support Chen Jing D(Mark)
2015-02-10 7:02 ` [dpdk-dev] [PATCH v3 15/15] fm10k: add PF and VF interrupt handling function Chen Jing D(Mark)
2015-02-04 10:40 ` [dpdk-dev] [PATCH v2 02/15] fm10k: add fm10k device id Chen Jing D(Mark)
2015-02-04 10:40 ` [dpdk-dev] [PATCH v2 03/15] fm10k: register fm10k pmd PF driver Chen Jing D(Mark)
2015-02-04 10:40 ` [dpdk-dev] [PATCH v2 04/15] Change config files to add fm10k into compile Chen Jing D(Mark)
2015-02-04 10:40 ` [dpdk-dev] [PATCH v2 05/15] fm10k: add reta update/requery functions Chen Jing D(Mark)
2015-02-04 10:40 ` [dpdk-dev] [PATCH v2 06/15] fm10k: add rx_queue_setup/release function Chen Jing D(Mark)
2015-02-04 10:40 ` [dpdk-dev] [PATCH v2 07/15] fm10k: add tx_queue_setup/release function Chen Jing D(Mark)
2015-02-04 10:40 ` [dpdk-dev] [PATCH v2 08/15] fm10k: add RX/TX single queue start/stop function Chen Jing D(Mark)
2015-02-04 10:40 ` [dpdk-dev] [PATCH v2 09/15] fm10k: add dev start/stop functions Chen Jing D(Mark)
2015-02-04 10:40 ` [dpdk-dev] [PATCH v2 10/15] fm10k: add receive and tranmit function Chen Jing D(Mark)
2015-02-04 10:40 ` [dpdk-dev] [PATCH v2 11/15] fm10k: add PF RSS support Chen Jing D(Mark)
2015-02-04 10:40 ` [dpdk-dev] [PATCH v2 12/15] fm10k: Add scatter receive function Chen Jing D(Mark)
2015-02-04 10:40 ` [dpdk-dev] [PATCH v2 13/15] fm10k: add function to set vlan Chen Jing D(Mark)
2015-02-04 10:40 ` [dpdk-dev] [PATCH v2 14/15] fm10k: Add SRIOV-VF support Chen Jing D(Mark)
2015-02-04 10:41 ` [dpdk-dev] [PATCH v2 15/15] fm10k: add PF and VF interrupt handling function Chen Jing D(Mark)
2015-01-30 5:07 ` [dpdk-dev] [PATCH 02/18] Change config/ files to add macros for fm10k Chen Jing D(Mark)
2015-01-30 5:07 ` [dpdk-dev] [PATCH 03/18] fm10k: Add empty fm10k files Chen Jing D(Mark)
2015-01-31 14:02 ` Neil Horman
2015-02-02 5:34 ` Chen, Jing D
[not found] ` <20150202133848.GA21700@hmsreliant.think-freely.org>
2015-02-03 6:47 ` Chen, Jing D
2015-02-01 13:01 ` David Marchand
2015-01-30 5:07 ` [dpdk-dev] [PATCH 04/18] fm10k: add fm10k device id Chen Jing D(Mark)
2015-01-31 14:19 ` Neil Horman
2015-01-31 16:07 ` David Marchand
2015-01-31 16:32 ` Neil Horman
2015-01-31 16:55 ` David Marchand
2015-01-31 18:35 ` Neil Horman
2015-05-07 11:06 ` David Marchand
2015-05-07 13:36 ` Neil Horman
2015-05-07 13:39 ` David Marchand
2015-02-02 7:54 ` Chen, Jing D
2015-01-30 5:07 ` [dpdk-dev] [PATCH 05/18] fm10k: Add code to register fm10k pmd PF driver Chen Jing D(Mark)
2015-01-30 5:07 ` [dpdk-dev] [PATCH 06/18] fm10k: add reta update/requery functions Chen Jing D(Mark)
2015-01-30 5:07 ` [dpdk-dev] [PATCH 07/18] fm10k: add rx_queue_setup/release function Chen Jing D(Mark)
2015-01-30 5:07 ` [dpdk-dev] [PATCH 08/18] fm10k: add tx_queue_setup/release function Chen Jing D(Mark)
2015-01-30 5:07 ` [dpdk-dev] [PATCH 09/18] fm10k: add RX/TX single queue start/stop function Chen Jing D(Mark)
2015-01-30 5:07 ` [dpdk-dev] [PATCH 10/18] fm10k: add dev start/stop functions Chen Jing D(Mark)
2015-02-04 2:36 ` Qiu, Michael [this message]
2015-02-04 9:55 ` Chen, Jing D
2015-01-30 5:07 ` [dpdk-dev] [PATCH 11/18] fm10k: add receive and tranmit function Chen Jing D(Mark)
2015-01-30 5:07 ` [dpdk-dev] [PATCH 12/18] fm10k: add PF RSS support Chen Jing D(Mark)
2015-02-01 0:38 ` Neil Horman
2015-01-30 5:07 ` [dpdk-dev] [PATCH 13/18] fm10k: Add scatter receive function Chen Jing D(Mark)
2015-01-30 5:07 ` [dpdk-dev] [PATCH 14/18] fm10k: add function to set vlan Chen Jing D(Mark)
2015-01-30 5:07 ` [dpdk-dev] [PATCH 15/18] fm10k: Add SRIOV-VF support Chen Jing D(Mark)
2015-01-30 5:07 ` [dpdk-dev] [PATCH 16/18] fm10k: add PF and VF interrupt handling function Chen Jing D(Mark)
2015-02-01 0:42 ` Neil Horman
2015-02-02 7:59 ` Chen, Jing D
2015-01-30 5:07 ` [dpdk-dev] [PATCH 17/18] Change lib/Makefile to add fm10k driver into compile list Chen Jing D(Mark)
2015-01-30 5:07 ` [dpdk-dev] [PATCH 18/18] Change mk/rte.app.mk to add fm10k lib into link Chen Jing D(Mark)
2015-02-01 0:50 ` Neil Horman
2015-02-02 8:10 ` Chen, Jing D
2015-01-30 21:26 ` [dpdk-dev] [PATCH 00/18] lib/librte_pmd_fm10k : fm10k pmd driver Neil Horman
2015-01-30 21:46 ` Jeff Shaw
2015-01-30 22:19 ` Thomas Monjalon
2015-02-02 2:59 ` Chen, Jing D
2015-02-02 8:19 ` Thomas Monjalon
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=533710CFB86FA344BFBF2D6802E60286CD4285@SHSMSX101.ccr.corp.intel.com \
--to=michael.qiu@intel.com \
--cc=dev@dpdk.org \
--cc=jing.d.chen@intel.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).