sfc: Move siena_nic_data::ipv6_rss_key to efx_nic::rx_hash_key
We will use this hash key for Toeplitz IPv4 hashing too. Signed-off-by: Ben Hutchings <bhutchings@solarflare.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
604f6049ba
commit
5d3a6fca95
|
@ -1134,6 +1134,9 @@ static int efx_probe_nic(struct efx_nic *efx)
|
||||||
* in MSI-X interrupts. */
|
* in MSI-X interrupts. */
|
||||||
efx_probe_interrupts(efx);
|
efx_probe_interrupts(efx);
|
||||||
|
|
||||||
|
if (efx->n_channels > 1)
|
||||||
|
get_random_bytes(&efx->rx_hash_key, sizeof(efx->rx_hash_key));
|
||||||
|
|
||||||
efx_set_channels(efx);
|
efx_set_channels(efx);
|
||||||
efx->net_dev->real_num_tx_queues = efx->n_tx_channels;
|
efx->net_dev->real_num_tx_queues = efx->n_tx_channels;
|
||||||
|
|
||||||
|
|
|
@ -735,6 +735,7 @@ struct efx_nic {
|
||||||
unsigned n_tx_channels;
|
unsigned n_tx_channels;
|
||||||
unsigned int rx_buffer_len;
|
unsigned int rx_buffer_len;
|
||||||
unsigned int rx_buffer_order;
|
unsigned int rx_buffer_order;
|
||||||
|
u8 rx_hash_key[40];
|
||||||
|
|
||||||
unsigned int_error_count;
|
unsigned int_error_count;
|
||||||
unsigned long int_error_expire;
|
unsigned long int_error_expire;
|
||||||
|
|
|
@ -142,7 +142,6 @@ struct siena_nic_data {
|
||||||
u32 fw_build;
|
u32 fw_build;
|
||||||
struct efx_mcdi_iface mcdi;
|
struct efx_mcdi_iface mcdi;
|
||||||
int wol_filter_id;
|
int wol_filter_id;
|
||||||
u8 ipv6_rss_key[40];
|
|
||||||
};
|
};
|
||||||
|
|
||||||
extern void siena_print_fwver(struct efx_nic *efx, char *buf, size_t len);
|
extern void siena_print_fwver(struct efx_nic *efx, char *buf, size_t len);
|
||||||
|
|
|
@ -285,9 +285,6 @@ static int siena_probe_nic(struct efx_nic *efx)
|
||||||
goto fail5;
|
goto fail5;
|
||||||
}
|
}
|
||||||
|
|
||||||
get_random_bytes(&nic_data->ipv6_rss_key,
|
|
||||||
sizeof(nic_data->ipv6_rss_key));
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
fail5:
|
fail5:
|
||||||
|
@ -307,7 +304,6 @@ fail1:
|
||||||
*/
|
*/
|
||||||
static int siena_init_nic(struct efx_nic *efx)
|
static int siena_init_nic(struct efx_nic *efx)
|
||||||
{
|
{
|
||||||
struct siena_nic_data *nic_data = efx->nic_data;
|
|
||||||
efx_oword_t temp;
|
efx_oword_t temp;
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
|
@ -336,16 +332,16 @@ static int siena_init_nic(struct efx_nic *efx)
|
||||||
efx_writeo(efx, &temp, FR_AZ_RX_CFG);
|
efx_writeo(efx, &temp, FR_AZ_RX_CFG);
|
||||||
|
|
||||||
/* Enable IPv6 RSS */
|
/* Enable IPv6 RSS */
|
||||||
BUILD_BUG_ON(sizeof(nic_data->ipv6_rss_key) !=
|
BUILD_BUG_ON(sizeof(efx->rx_hash_key) <
|
||||||
2 * sizeof(temp) + FRF_CZ_RX_RSS_IPV6_TKEY_HI_WIDTH / 8 ||
|
2 * sizeof(temp) + FRF_CZ_RX_RSS_IPV6_TKEY_HI_WIDTH / 8 ||
|
||||||
FRF_CZ_RX_RSS_IPV6_TKEY_HI_LBN != 0);
|
FRF_CZ_RX_RSS_IPV6_TKEY_HI_LBN != 0);
|
||||||
memcpy(&temp, nic_data->ipv6_rss_key, sizeof(temp));
|
memcpy(&temp, efx->rx_hash_key, sizeof(temp));
|
||||||
efx_writeo(efx, &temp, FR_CZ_RX_RSS_IPV6_REG1);
|
efx_writeo(efx, &temp, FR_CZ_RX_RSS_IPV6_REG1);
|
||||||
memcpy(&temp, nic_data->ipv6_rss_key + sizeof(temp), sizeof(temp));
|
memcpy(&temp, efx->rx_hash_key + sizeof(temp), sizeof(temp));
|
||||||
efx_writeo(efx, &temp, FR_CZ_RX_RSS_IPV6_REG2);
|
efx_writeo(efx, &temp, FR_CZ_RX_RSS_IPV6_REG2);
|
||||||
EFX_POPULATE_OWORD_2(temp, FRF_CZ_RX_RSS_IPV6_THASH_ENABLE, 1,
|
EFX_POPULATE_OWORD_2(temp, FRF_CZ_RX_RSS_IPV6_THASH_ENABLE, 1,
|
||||||
FRF_CZ_RX_RSS_IPV6_IP_THASH_ENABLE, 1);
|
FRF_CZ_RX_RSS_IPV6_IP_THASH_ENABLE, 1);
|
||||||
memcpy(&temp, nic_data->ipv6_rss_key + 2 * sizeof(temp),
|
memcpy(&temp, efx->rx_hash_key + 2 * sizeof(temp),
|
||||||
FRF_CZ_RX_RSS_IPV6_TKEY_HI_WIDTH / 8);
|
FRF_CZ_RX_RSS_IPV6_TKEY_HI_WIDTH / 8);
|
||||||
efx_writeo(efx, &temp, FR_CZ_RX_RSS_IPV6_REG3);
|
efx_writeo(efx, &temp, FR_CZ_RX_RSS_IPV6_REG3);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue