diff options
author | Eric Dumazet <eric.dumazet@gmail.com> | 2010-02-16 00:51:33 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-02-16 00:51:33 -0500 |
commit | 339c6e99853d2ef1f02ad8a313e079050a300427 (patch) | |
tree | 0c442d67a328b5cf1fa33a8cb41ebcdb0618cda8 | |
parent | 5cdaaa12866e916d0ada8b56c5f0e543cfc7fe3d (diff) |
ethtool: reduce stack usage
dev_ethtool() is currently using 604 bytes of stack, even with gcc-4.4.2
objdump -d vmlinux | scripts/checkstack.pl
...
0xc04bbc33 dev_ethtool [vmlinux]: 604
...
Adding noinline attributes to selected functions can reduce stack usage.
Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | net/core/ethtool.c | 35 |
1 files changed, 28 insertions, 7 deletions
diff --git a/net/core/ethtool.c b/net/core/ethtool.c index 794cf57078cd..82cae3bca78d 100644 --- a/net/core/ethtool.c +++ b/net/core/ethtool.c | |||
@@ -197,7 +197,10 @@ static int ethtool_set_settings(struct net_device *dev, void __user *useraddr) | |||
197 | return dev->ethtool_ops->set_settings(dev, &cmd); | 197 | return dev->ethtool_ops->set_settings(dev, &cmd); |
198 | } | 198 | } |
199 | 199 | ||
200 | static int ethtool_get_drvinfo(struct net_device *dev, void __user *useraddr) | 200 | /* |
201 | * noinline attribute so that gcc doesnt use too much stack in dev_ethtool() | ||
202 | */ | ||
203 | static noinline int ethtool_get_drvinfo(struct net_device *dev, void __user *useraddr) | ||
201 | { | 204 | { |
202 | struct ethtool_drvinfo info; | 205 | struct ethtool_drvinfo info; |
203 | const struct ethtool_ops *ops = dev->ethtool_ops; | 206 | const struct ethtool_ops *ops = dev->ethtool_ops; |
@@ -232,7 +235,10 @@ static int ethtool_get_drvinfo(struct net_device *dev, void __user *useraddr) | |||
232 | return 0; | 235 | return 0; |
233 | } | 236 | } |
234 | 237 | ||
235 | static int ethtool_set_rxnfc(struct net_device *dev, void __user *useraddr) | 238 | /* |
239 | * noinline attribute so that gcc doesnt use too much stack in dev_ethtool() | ||
240 | */ | ||
241 | static noinline int ethtool_set_rxnfc(struct net_device *dev, void __user *useraddr) | ||
236 | { | 242 | { |
237 | struct ethtool_rxnfc cmd; | 243 | struct ethtool_rxnfc cmd; |
238 | 244 | ||
@@ -245,7 +251,10 @@ static int ethtool_set_rxnfc(struct net_device *dev, void __user *useraddr) | |||
245 | return dev->ethtool_ops->set_rxnfc(dev, &cmd); | 251 | return dev->ethtool_ops->set_rxnfc(dev, &cmd); |
246 | } | 252 | } |
247 | 253 | ||
248 | static int ethtool_get_rxnfc(struct net_device *dev, void __user *useraddr) | 254 | /* |
255 | * noinline attribute so that gcc doesnt use too much stack in dev_ethtool() | ||
256 | */ | ||
257 | static noinline int ethtool_get_rxnfc(struct net_device *dev, void __user *useraddr) | ||
249 | { | 258 | { |
250 | struct ethtool_rxnfc info; | 259 | struct ethtool_rxnfc info; |
251 | const struct ethtool_ops *ops = dev->ethtool_ops; | 260 | const struct ethtool_ops *ops = dev->ethtool_ops; |
@@ -317,7 +326,10 @@ static void __rx_ntuple_filter_add(struct ethtool_rx_ntuple_list *list, | |||
317 | list->count++; | 326 | list->count++; |
318 | } | 327 | } |
319 | 328 | ||
320 | static int ethtool_set_rx_ntuple(struct net_device *dev, void __user *useraddr) | 329 | /* |
330 | * noinline attribute so that gcc doesnt use too much stack in dev_ethtool() | ||
331 | */ | ||
332 | static noinline int ethtool_set_rx_ntuple(struct net_device *dev, void __user *useraddr) | ||
321 | { | 333 | { |
322 | struct ethtool_rx_ntuple cmd; | 334 | struct ethtool_rx_ntuple cmd; |
323 | const struct ethtool_ops *ops = dev->ethtool_ops; | 335 | const struct ethtool_ops *ops = dev->ethtool_ops; |
@@ -788,7 +800,10 @@ static int ethtool_set_eeprom(struct net_device *dev, void __user *useraddr) | |||
788 | return ret; | 800 | return ret; |
789 | } | 801 | } |
790 | 802 | ||
791 | static int ethtool_get_coalesce(struct net_device *dev, void __user *useraddr) | 803 | /* |
804 | * noinline attribute so that gcc doesnt use too much stack in dev_ethtool() | ||
805 | */ | ||
806 | static noinline int ethtool_get_coalesce(struct net_device *dev, void __user *useraddr) | ||
792 | { | 807 | { |
793 | struct ethtool_coalesce coalesce = { .cmd = ETHTOOL_GCOALESCE }; | 808 | struct ethtool_coalesce coalesce = { .cmd = ETHTOOL_GCOALESCE }; |
794 | 809 | ||
@@ -802,7 +817,10 @@ static int ethtool_get_coalesce(struct net_device *dev, void __user *useraddr) | |||
802 | return 0; | 817 | return 0; |
803 | } | 818 | } |
804 | 819 | ||
805 | static int ethtool_set_coalesce(struct net_device *dev, void __user *useraddr) | 820 | /* |
821 | * noinline attribute so that gcc doesnt use too much stack in dev_ethtool() | ||
822 | */ | ||
823 | static noinline int ethtool_set_coalesce(struct net_device *dev, void __user *useraddr) | ||
806 | { | 824 | { |
807 | struct ethtool_coalesce coalesce; | 825 | struct ethtool_coalesce coalesce; |
808 | 826 | ||
@@ -1212,7 +1230,10 @@ static int ethtool_set_value(struct net_device *dev, char __user *useraddr, | |||
1212 | return actor(dev, edata.data); | 1230 | return actor(dev, edata.data); |
1213 | } | 1231 | } |
1214 | 1232 | ||
1215 | static int ethtool_flash_device(struct net_device *dev, char __user *useraddr) | 1233 | /* |
1234 | * noinline attribute so that gcc doesnt use too much stack in dev_ethtool() | ||
1235 | */ | ||
1236 | static noinline int ethtool_flash_device(struct net_device *dev, char __user *useraddr) | ||
1216 | { | 1237 | { |
1217 | struct ethtool_flash efl; | 1238 | struct ethtool_flash efl; |
1218 | 1239 | ||