diff options
author | Andrey Yurovsky <andrey@cozybit.com> | 2009-08-13 20:34:40 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2009-08-20 11:35:50 -0400 |
commit | 6f632d57f35303118685b88c139f3da73df077e2 (patch) | |
tree | 687a6547ca2dfb65204df9bc8a2e724a3c9a6899 /drivers/net/wireless | |
parent | b23da49e6db341f4721476394dd8b95e0be2d179 (diff) |
libertas: don't use dynamic-sized array
sparse complains about a bad constant expression due to the use of a
dynamic-sized array in get_common_rates(). Allocate and free the array
instead.
Signed-off-by: Andrey Yurovsky <andrey@cozybit.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless')
-rw-r--r-- | drivers/net/wireless/libertas/assoc.c | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/drivers/net/wireless/libertas/assoc.c b/drivers/net/wireless/libertas/assoc.c index 385b50f4b105..81f86ef26990 100644 --- a/drivers/net/wireless/libertas/assoc.c +++ b/drivers/net/wireless/libertas/assoc.c | |||
@@ -45,9 +45,14 @@ static int get_common_rates(struct lbs_private *priv, | |||
45 | u8 *card_rates = lbs_bg_rates; | 45 | u8 *card_rates = lbs_bg_rates; |
46 | size_t num_card_rates = sizeof(lbs_bg_rates); | 46 | size_t num_card_rates = sizeof(lbs_bg_rates); |
47 | int ret = 0, i, j; | 47 | int ret = 0, i, j; |
48 | u8 tmp[30]; | 48 | u8 *tmp; |
49 | size_t tmp_size = 0; | 49 | size_t tmp_size = 0; |
50 | 50 | ||
51 | tmp = kzalloc((ARRAY_SIZE(lbs_bg_rates) - 1) * (*rates_size - 1), | ||
52 | GFP_KERNEL); | ||
53 | if (!tmp) | ||
54 | return -1; | ||
55 | |||
51 | /* For each rate in card_rates that exists in rate1, copy to tmp */ | 56 | /* For each rate in card_rates that exists in rate1, copy to tmp */ |
52 | for (i = 0; card_rates[i] && (i < num_card_rates); i++) { | 57 | for (i = 0; card_rates[i] && (i < num_card_rates); i++) { |
53 | for (j = 0; rates[j] && (j < *rates_size); j++) { | 58 | for (j = 0; rates[j] && (j < *rates_size); j++) { |
@@ -77,6 +82,7 @@ done: | |||
77 | memset(rates, 0, *rates_size); | 82 | memset(rates, 0, *rates_size); |
78 | *rates_size = min_t(int, tmp_size, *rates_size); | 83 | *rates_size = min_t(int, tmp_size, *rates_size); |
79 | memcpy(rates, tmp, *rates_size); | 84 | memcpy(rates, tmp, *rates_size); |
85 | kfree(tmp); | ||
80 | return ret; | 86 | return ret; |
81 | } | 87 | } |
82 | 88 | ||