aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/net/wireless/b43/b43.h16
-rw-r--r--drivers/net/wireless/b43/lo.c4
-rw-r--r--drivers/net/wireless/b43/main.c8
-rw-r--r--drivers/net/wireless/b43/phy.c24
4 files changed, 18 insertions, 34 deletions
diff --git a/drivers/net/wireless/b43/b43.h b/drivers/net/wireless/b43/b43.h
index 7d034df250bd..0c2bc061e8f3 100644
--- a/drivers/net/wireless/b43/b43.h
+++ b/drivers/net/wireless/b43/b43.h
@@ -939,22 +939,6 @@ static inline bool __b43_warn_on_dummy(bool x) { return x; }
939# define B43_WARN_ON(x) __b43_warn_on_dummy(unlikely(!!(x))) 939# define B43_WARN_ON(x) __b43_warn_on_dummy(unlikely(!!(x)))
940#endif 940#endif
941 941
942/** Limit a value between two limits */
943#ifdef limit_value
944# undef limit_value
945#endif
946#define limit_value(value, min, max) \
947 ({ \
948 typeof(value) __value = (value); \
949 typeof(value) __min = (min); \
950 typeof(value) __max = (max); \
951 if (__value < __min) \
952 __value = __min; \
953 else if (__value > __max) \
954 __value = __max; \
955 __value; \
956 })
957
958/* Convert an integer to a Q5.2 value */ 942/* Convert an integer to a Q5.2 value */
959#define INT_TO_Q52(i) ((i) << 2) 943#define INT_TO_Q52(i) ((i) << 2)
960/* Convert a Q5.2 value to an integer (precision loss!) */ 944/* Convert a Q5.2 value to an integer (precision loss!) */
diff --git a/drivers/net/wireless/b43/lo.c b/drivers/net/wireless/b43/lo.c
index 4ce1e3561205..9c854d6aae36 100644
--- a/drivers/net/wireless/b43/lo.c
+++ b/drivers/net/wireless/b43/lo.c
@@ -199,7 +199,7 @@ static void lo_measure_txctl_values(struct b43_wldev *dev)
199 if (lb_gain > 10) { 199 if (lb_gain > 10) {
200 radio_pctl_reg = 0; 200 radio_pctl_reg = 0;
201 pga = abs(10 - lb_gain) / 6; 201 pga = abs(10 - lb_gain) / 6;
202 pga = limit_value(pga, 0, 15); 202 pga = clamp_val(pga, 0, 15);
203 } else { 203 } else {
204 int cmp_val; 204 int cmp_val;
205 int tmp; 205 int tmp;
@@ -321,7 +321,7 @@ static void lo_measure_gain_values(struct b43_wldev *dev,
321 phy->lna_lod_gain = 1; 321 phy->lna_lod_gain = 1;
322 trsw_rx_gain -= 8; 322 trsw_rx_gain -= 8;
323 } 323 }
324 trsw_rx_gain = limit_value(trsw_rx_gain, 0, 0x2D); 324 trsw_rx_gain = clamp_val(trsw_rx_gain, 0, 0x2D);
325 phy->pga_gain = trsw_rx_gain / 3; 325 phy->pga_gain = trsw_rx_gain / 3;
326 if (phy->pga_gain >= 5) { 326 if (phy->pga_gain >= 5) {
327 phy->pga_gain -= 5; 327 phy->pga_gain -= 5;
diff --git a/drivers/net/wireless/b43/main.c b/drivers/net/wireless/b43/main.c
index c6e79a15d3cb..7c23aa8705c2 100644
--- a/drivers/net/wireless/b43/main.c
+++ b/drivers/net/wireless/b43/main.c
@@ -1182,10 +1182,10 @@ static void handle_irq_noise(struct b43_wldev *dev)
1182 /* Get the noise samples. */ 1182 /* Get the noise samples. */
1183 B43_WARN_ON(dev->noisecalc.nr_samples >= 8); 1183 B43_WARN_ON(dev->noisecalc.nr_samples >= 8);
1184 i = dev->noisecalc.nr_samples; 1184 i = dev->noisecalc.nr_samples;
1185 noise[0] = limit_value(noise[0], 0, ARRAY_SIZE(phy->nrssi_lt) - 1); 1185 noise[0] = clamp_val(noise[0], 0, ARRAY_SIZE(phy->nrssi_lt) - 1);
1186 noise[1] = limit_value(noise[1], 0, ARRAY_SIZE(phy->nrssi_lt) - 1); 1186 noise[1] = clamp_val(noise[1], 0, ARRAY_SIZE(phy->nrssi_lt) - 1);
1187 noise[2] = limit_value(noise[2], 0, ARRAY_SIZE(phy->nrssi_lt) - 1); 1187 noise[2] = clamp_val(noise[2], 0, ARRAY_SIZE(phy->nrssi_lt) - 1);
1188 noise[3] = limit_value(noise[3], 0, ARRAY_SIZE(phy->nrssi_lt) - 1); 1188 noise[3] = clamp_val(noise[3], 0, ARRAY_SIZE(phy->nrssi_lt) - 1);
1189 dev->noisecalc.samples[i][0] = phy->nrssi_lt[noise[0]]; 1189 dev->noisecalc.samples[i][0] = phy->nrssi_lt[noise[0]];
1190 dev->noisecalc.samples[i][1] = phy->nrssi_lt[noise[1]]; 1190 dev->noisecalc.samples[i][1] = phy->nrssi_lt[noise[1]];
1191 dev->noisecalc.samples[i][2] = phy->nrssi_lt[noise[2]]; 1191 dev->noisecalc.samples[i][2] = phy->nrssi_lt[noise[2]];
diff --git a/drivers/net/wireless/b43/phy.c b/drivers/net/wireless/b43/phy.c
index 8b3c24da8db9..6378c266549a 100644
--- a/drivers/net/wireless/b43/phy.c
+++ b/drivers/net/wireless/b43/phy.c
@@ -1415,7 +1415,7 @@ static void b43_phy_initg(struct b43_wldev *dev)
1415 * the value 0x7FFFFFFF here. I think that is some weird 1415 * the value 0x7FFFFFFF here. I think that is some weird
1416 * compiler optimization in the original driver. 1416 * compiler optimization in the original driver.
1417 * Essentially, what we do here is resetting all NRSSI LT 1417 * Essentially, what we do here is resetting all NRSSI LT
1418 * entries to -32 (see the limit_value() in nrssi_hw_update()) 1418 * entries to -32 (see the clamp_val() in nrssi_hw_update())
1419 */ 1419 */
1420 b43_nrssi_hw_update(dev, 0xFFFF); //FIXME? 1420 b43_nrssi_hw_update(dev, 0xFFFF); //FIXME?
1421 b43_calc_nrssi_threshold(dev); 1421 b43_calc_nrssi_threshold(dev);
@@ -1477,13 +1477,13 @@ static s8 b43_phy_estimate_power_out(struct b43_wldev *dev, s8 tssi)
1477 switch (phy->type) { 1477 switch (phy->type) {
1478 case B43_PHYTYPE_A: 1478 case B43_PHYTYPE_A:
1479 tmp += 0x80; 1479 tmp += 0x80;
1480 tmp = limit_value(tmp, 0x00, 0xFF); 1480 tmp = clamp_val(tmp, 0x00, 0xFF);
1481 dbm = phy->tssi2dbm[tmp]; 1481 dbm = phy->tssi2dbm[tmp];
1482 //TODO: There's a FIXME on the specs 1482 //TODO: There's a FIXME on the specs
1483 break; 1483 break;
1484 case B43_PHYTYPE_B: 1484 case B43_PHYTYPE_B:
1485 case B43_PHYTYPE_G: 1485 case B43_PHYTYPE_G:
1486 tmp = limit_value(tmp, 0x00, 0x3F); 1486 tmp = clamp_val(tmp, 0x00, 0x3F);
1487 dbm = phy->tssi2dbm[tmp]; 1487 dbm = phy->tssi2dbm[tmp];
1488 break; 1488 break;
1489 default: 1489 default:
@@ -1542,8 +1542,8 @@ void b43_put_attenuation_into_ranges(struct b43_wldev *dev,
1542 break; 1542 break;
1543 } 1543 }
1544 1544
1545 *_rfatt = limit_value(rfatt, rf_min, rf_max); 1545 *_rfatt = clamp_val(rfatt, rf_min, rf_max);
1546 *_bbatt = limit_value(bbatt, bb_min, bb_max); 1546 *_bbatt = clamp_val(bbatt, bb_min, bb_max);
1547} 1547}
1548 1548
1549/* http://bcm-specs.sipsolutions.net/RecalculateTransmissionPower */ 1549/* http://bcm-specs.sipsolutions.net/RecalculateTransmissionPower */
@@ -1638,7 +1638,7 @@ void b43_phy_xmitpower(struct b43_wldev *dev)
1638 /* Get desired power (in Q5.2) */ 1638 /* Get desired power (in Q5.2) */
1639 desired_pwr = INT_TO_Q52(phy->power_level); 1639 desired_pwr = INT_TO_Q52(phy->power_level);
1640 /* And limit it. max_pwr already is Q5.2 */ 1640 /* And limit it. max_pwr already is Q5.2 */
1641 desired_pwr = limit_value(desired_pwr, 0, max_pwr); 1641 desired_pwr = clamp_val(desired_pwr, 0, max_pwr);
1642 if (b43_debug(dev, B43_DBG_XMITPOWER)) { 1642 if (b43_debug(dev, B43_DBG_XMITPOWER)) {
1643 b43dbg(dev->wl, 1643 b43dbg(dev->wl,
1644 "Current TX power output: " Q52_FMT 1644 "Current TX power output: " Q52_FMT
@@ -1748,7 +1748,7 @@ static inline
1748 f = q; 1748 f = q;
1749 i++; 1749 i++;
1750 } while (delta >= 2); 1750 } while (delta >= 2);
1751 entry[index] = limit_value(b43_tssi2dbm_ad(m1 * f, 8192), -127, 128); 1751 entry[index] = clamp_val(b43_tssi2dbm_ad(m1 * f, 8192), -127, 128);
1752 return 0; 1752 return 0;
1753} 1753}
1754 1754
@@ -2274,7 +2274,7 @@ void b43_nrssi_hw_update(struct b43_wldev *dev, u16 val)
2274 for (i = 0; i < 64; i++) { 2274 for (i = 0; i < 64; i++) {
2275 tmp = b43_nrssi_hw_read(dev, i); 2275 tmp = b43_nrssi_hw_read(dev, i);
2276 tmp -= val; 2276 tmp -= val;
2277 tmp = limit_value(tmp, -32, 31); 2277 tmp = clamp_val(tmp, -32, 31);
2278 b43_nrssi_hw_write(dev, i, tmp); 2278 b43_nrssi_hw_write(dev, i, tmp);
2279 } 2279 }
2280} 2280}
@@ -2291,7 +2291,7 @@ void b43_nrssi_mem_update(struct b43_wldev *dev)
2291 tmp = (i - delta) * phy->nrssislope; 2291 tmp = (i - delta) * phy->nrssislope;
2292 tmp /= 0x10000; 2292 tmp /= 0x10000;
2293 tmp += 0x3A; 2293 tmp += 0x3A;
2294 tmp = limit_value(tmp, 0, 0x3F); 2294 tmp = clamp_val(tmp, 0, 0x3F);
2295 phy->nrssi_lt[i] = tmp; 2295 phy->nrssi_lt[i] = tmp;
2296 } 2296 }
2297} 2297}
@@ -2728,7 +2728,7 @@ void b43_calc_nrssi_threshold(struct b43_wldev *dev)
2728 } else 2728 } else
2729 threshold = phy->nrssi[1] - 5; 2729 threshold = phy->nrssi[1] - 5;
2730 2730
2731 threshold = limit_value(threshold, 0, 0x3E); 2731 threshold = clamp_val(threshold, 0, 0x3E);
2732 b43_phy_read(dev, 0x0020); /* dummy read */ 2732 b43_phy_read(dev, 0x0020); /* dummy read */
2733 b43_phy_write(dev, 0x0020, 2733 b43_phy_write(dev, 0x0020,
2734 (((u16) threshold) << 8) | 0x001C); 2734 (((u16) threshold) << 8) | 0x001C);
@@ -2779,7 +2779,7 @@ void b43_calc_nrssi_threshold(struct b43_wldev *dev)
2779 else 2779 else
2780 a += 32; 2780 a += 32;
2781 a = a >> 6; 2781 a = a >> 6;
2782 a = limit_value(a, -31, 31); 2782 a = clamp_val(a, -31, 31);
2783 2783
2784 b = b * (phy->nrssi[1] - phy->nrssi[0]); 2784 b = b * (phy->nrssi[1] - phy->nrssi[0]);
2785 b += (phy->nrssi[0] << 6); 2785 b += (phy->nrssi[0] << 6);
@@ -2788,7 +2788,7 @@ void b43_calc_nrssi_threshold(struct b43_wldev *dev)
2788 else 2788 else
2789 b += 32; 2789 b += 32;
2790 b = b >> 6; 2790 b = b >> 6;
2791 b = limit_value(b, -31, 31); 2791 b = clamp_val(b, -31, 31);
2792 2792
2793 tmp_u16 = b43_phy_read(dev, 0x048A) & 0xF000; 2793 tmp_u16 = b43_phy_read(dev, 0x048A) & 0xF000;
2794 tmp_u16 |= ((u32) b & 0x0000003F); 2794 tmp_u16 |= ((u32) b & 0x0000003F);