From: Greg Kroah-Hartman Date: Tue, 3 Mar 2020 11:59:14 +0000 (+0100) Subject: 4.19-stable patches X-Git-Tag: v4.19.108~36 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=c0d687df0c40aacde6d16ed4fd5ba14d9440ba34;p=thirdparty%2Fkernel%2Fstable-queue.git 4.19-stable patches added patches: net-ena-make-ena-rxfh-support-eth_rss_hash_no_change.patch --- diff --git a/queue-4.19/net-ena-make-ena-rxfh-support-eth_rss_hash_no_change.patch b/queue-4.19/net-ena-make-ena-rxfh-support-eth_rss_hash_no_change.patch new file mode 100644 index 00000000000..827e4a0185c --- /dev/null +++ b/queue-4.19/net-ena-make-ena-rxfh-support-eth_rss_hash_no_change.patch @@ -0,0 +1,72 @@ +From 470793a78ce344bd53d31e0c2d537f71ba957547 Mon Sep 17 00:00:00 2001 +From: Arthur Kiyanovski +Date: Tue, 11 Feb 2020 15:17:49 +0000 +Subject: net: ena: make ena rxfh support ETH_RSS_HASH_NO_CHANGE + +From: Arthur Kiyanovski + +commit 470793a78ce344bd53d31e0c2d537f71ba957547 upstream. + +As the name suggests ETH_RSS_HASH_NO_CHANGE is received upon changing +the key or indirection table using ethtool while keeping the same hash +function. + +Also add a function for retrieving the current hash function from +the ena-com layer. + +Fixes: 1738cd3ed342 ("net: ena: Add a driver for Amazon Elastic Network Adapters (ENA)") +Signed-off-by: Sameeh Jubran +Signed-off-by: Saeed Bshara +Signed-off-by: Arthur Kiyanovski +Signed-off-by: David S. Miller +Signed-off-by: Greg Kroah-Hartman + +--- + drivers/net/ethernet/amazon/ena/ena_com.c | 5 +++++ + drivers/net/ethernet/amazon/ena/ena_com.h | 8 ++++++++ + drivers/net/ethernet/amazon/ena/ena_ethtool.c | 3 +++ + 3 files changed, 16 insertions(+) + +--- a/drivers/net/ethernet/amazon/ena/ena_com.c ++++ b/drivers/net/ethernet/amazon/ena/ena_com.c +@@ -860,6 +860,11 @@ static void ena_com_hash_key_fill_defaul + hash_key->keys_num = sizeof(hash_key->key) / sizeof(u32); + } + ++int ena_com_get_current_hash_function(struct ena_com_dev *ena_dev) ++{ ++ return ena_dev->rss.hash_func; ++} ++ + static int ena_com_hash_key_allocate(struct ena_com_dev *ena_dev) + { + struct ena_rss *rss = &ena_dev->rss; +--- a/drivers/net/ethernet/amazon/ena/ena_com.h ++++ b/drivers/net/ethernet/amazon/ena/ena_com.h +@@ -632,6 +632,14 @@ int ena_com_rss_init(struct ena_com_dev + */ + void ena_com_rss_destroy(struct ena_com_dev *ena_dev); + ++/* ena_com_get_current_hash_function - Get RSS hash function ++ * @ena_dev: ENA communication layer struct ++ * ++ * Return the current hash function. ++ * @return: 0 or one of the ena_admin_hash_functions values. ++ */ ++int ena_com_get_current_hash_function(struct ena_com_dev *ena_dev); ++ + /* ena_com_fill_hash_function - Fill RSS hash function + * @ena_dev: ENA communication layer struct + * @func: The hash function (Toeplitz or crc) +--- a/drivers/net/ethernet/amazon/ena/ena_ethtool.c ++++ b/drivers/net/ethernet/amazon/ena/ena_ethtool.c +@@ -749,6 +749,9 @@ static int ena_set_rxfh(struct net_devic + } + + switch (hfunc) { ++ case ETH_RSS_HASH_NO_CHANGE: ++ func = ena_com_get_current_hash_function(ena_dev); ++ break; + case ETH_RSS_HASH_TOP: + func = ENA_ADMIN_TOEPLITZ; + break; diff --git a/queue-4.19/series b/queue-4.19/series index 761b090e61f..1f7e5643ea3 100644 --- a/queue-4.19/series +++ b/queue-4.19/series @@ -63,3 +63,4 @@ net-netlink-cap-max-groups-which-will-be-considered-in-netlink_bind.patch net-atlantic-fix-use-after-free-kasan-warn.patch net-atlantic-fix-potential-error-handling.patch net-smc-no-peer-id-in-clc-decline-for-smcd.patch +net-ena-make-ena-rxfh-support-eth_rss_hash_no_change.patch