All of lore.kernel.org
 help / color / mirror / Atom feed
From: Vlad Zolotarov <vladz@cloudius-systems.com>
To: "Tantilov, Emil S" <emil.s.tantilov@intel.com>,
	"netdev@vger.kernel.org" <netdev@vger.kernel.org>
Cc: "Kirsher, Jeffrey T" <jeffrey.t.kirsher@intel.com>,
	"avi@cloudius-systems.com" <avi@cloudius-systems.com>,
	"gleb@cloudius-systems.com" <gleb@cloudius-systems.com>
Subject: Re: [PATCH net-next v7 3/7] ixgbe: Add a RETA query command to VF-PF channel API
Date: Wed, 25 Mar 2015 21:29:44 +0200	[thread overview]
Message-ID: <55130CA8.2030700@cloudius-systems.com> (raw)
In-Reply-To: <87618083B2453E4A8714035B62D6799250275A68@FMSMSX105.amr.corp.intel.com>



On 03/25/15 20:03, Tantilov, Emil S wrote:
>> -----Original Message-----
>> From: netdev-owner@vger.kernel.org [mailto:netdev-owner@vger.kernel.org] On Behalf Of Vlad Zolotarov
>> Sent: Tuesday, March 24, 2015 6:06 AM
>> Subject: [PATCH net-next v7 3/7] ixgbe: Add a RETA query command to VF-PF channel API
>>
>> 82599 and x540 VFs and PF share the same RSS redirection table (RETA). Therefore we
>> just return it for all VFs. x550 on the other hand provides a separate redirection
>> table for each VF (there is a per-pool RETA table).
>>
>> For 82599 and x540 RETA table is an array of 32 registers (128 bytes) and the maximum number of
>> registers that may be delivered in a single VF-PF channel command is 15. Therefore
>> we will deliver the whole table in 3 steps: 12, 12 and 8 registers in each
>> step correspondingly.
>>
>> For x550 VFs RETA is a 64 byte array, so we may deliver it in two steps: 12 and 4 registers
>> correspondingly.
>>
>> Thus this patch does the following:
>>
>>   - Adds a new API version (to specify a new commands set).
>>   - Adds the IXGBE_VF_GET_RETA command to the VF-PF commands set.
>>
>> Signed-off-by: Vlad Zolotarov <vladz@cloudius-systems.com>
>> ---
> <snip>
>
> +static int ixgbe_get_vf_reta(struct ixgbe_adapter *adapter, u32 *msgbuf, u32 vf)
> +{
> +	struct ixgbe_hw *hw = &adapter->hw;
> +	int i, j;
> +	u32 *reta = &msgbuf[1];
> +	u32 mask = 0;
> +	u32 psrtype;
> +	u32 reta_offset_dw = msgbuf[IXGBE_VF_RETA_OFFSET];
> +	u32 dwords = msgbuf[IXGBE_VF_RETA_SZ];
> +
> +	/* verify the PF is supporting the correct API */
> +	if (!adapter->vfinfo[vf].rss_query_enabled ||
> +	    (adapter->vfinfo[vf].vf_api != ixgbe_mbox_api_12))
> +		return -EPERM;
> +
> +	psrtype = IXGBE_READ_REG(hw, IXGBE_PSRTYPE(vf));
> +
> +	/* The redirection table is composed as follows:
> +	 * 82598: 128 (8 bit wide) entries containing pair of 4 bit RSS indices
> +	 * 82599/X540: 128 (8 bit wide) entries containing 4 bit RSS index X550:
> +	 * 512 (8 bit wide) entries containing 6 bit RSS index
> +	 *
> +	 * PSRTYPE[n].RQPL defines if 0, 1 or 2 bits from the redirection table
> +	 * value should be used.
> +	 */
> +
> +	if ((psrtype & (1 << 29)) == (1 << 29))
> +		mask = 0x01010101;
> +	else if ((psrtype & (2 << 29)) == (2 << 29))
> +		mask = 0x03030303;
> +	else
> +		mask = 0;
> +
> +	switch (hw->mac.type) {
> +	case ixgbe_mac_82599EB:
> +	case ixgbe_mac_X540:
> +		/* Read the appropriate portion of RETA */
> +		for (i = 0; i < dwords; i++)
> +			reta[i] = IXGBE_READ_REG(hw,
> +						IXGBE_RETA(i + reta_offset_dw));
> +		break;
> +	case ixgbe_mac_X550:
> +	case ixgbe_mac_X550EM_x:
> +		/* X550 has a per-VF RETA */
> +		for (i = 0, j = reta_offset_dw; i < dwords; i++, j++)
> +			reta[i] = IXGBE_READ_REG(hw,
> +						IXGBE_PFVFRETA(j, vf));
> +		break;
> +	default:
> +		return -1;
>
> There is no need to query the X550 info through the mailbox - this information can be obtained directly from the VF registers.

I couldn't find an x550 spec anywhere. Could u tell me where it may be found?


>
> Thanks,
> Emil
>

  reply	other threads:[~2015-03-25 19:29 UTC|newest]

Thread overview: 12+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-03-24 13:05 [PATCH net-next v7 0/7]: ixgbevf: Allow querying VFs RSS indirection table and key Vlad Zolotarov
2015-03-24 13:05 ` [PATCH net-next v7 1/7] if_link: Add an additional parameter to ifla_vf_info for RSS querying Vlad Zolotarov
2015-03-24 13:05 ` [PATCH net-next v7 2/7] ixgbe: Add a new netdev op to allow/prevent a VF from querying an RSS info Vlad Zolotarov
2015-03-24 13:05 ` [PATCH net-next v7 3/7] ixgbe: Add a RETA query command to VF-PF channel API Vlad Zolotarov
2015-03-25 18:03   ` Tantilov, Emil S
2015-03-25 19:29     ` Vlad Zolotarov [this message]
     [not found]     ` <55130AD2.4010509@cloudius-systems.com>
2015-03-25 19:33       ` Tantilov, Emil S
2015-03-25 19:51         ` Vlad Zolotarov
2015-03-24 13:05 ` [PATCH net-next v7 4/7] ixgbevf: Add a RETA query code Vlad Zolotarov
2015-03-24 13:05 ` [PATCH net-next v7 5/7] ixgbe: Add GET_RSS_KEY command to VF-PF channel commands set Vlad Zolotarov
2015-03-24 13:05 ` [PATCH net-next v7 6/7] ixgbevf: Add RSS Key query code Vlad Zolotarov
2015-03-24 13:05 ` [PATCH net-next v7 7/7] ixgbevf: Add the appropriate ethtool ops to query RSS indirection table and key Vlad Zolotarov

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=55130CA8.2030700@cloudius-systems.com \
    --to=vladz@cloudius-systems.com \
    --cc=avi@cloudius-systems.com \
    --cc=emil.s.tantilov@intel.com \
    --cc=gleb@cloudius-systems.com \
    --cc=jeffrey.t.kirsher@intel.com \
    --cc=netdev@vger.kernel.org \
    /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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.