summaryrefslogtreecommitdiff
path: root/sys/dev/pci
diff options
context:
space:
mode:
authorDamien Bergamini <damien@cvs.openbsd.org>2007-09-10 17:55:49 +0000
committerDamien Bergamini <damien@cvs.openbsd.org>2007-09-10 17:55:49 +0000
commitf436a7aa46be3fa4dcf4c6f4c0b74f99732428c5 (patch)
tree6a5fb586d9db155ce3baa6ec9464f48eef0004e3 /sys/dev/pci
parentd6bedf0e234dbea3a612ad8f5653fabb3b846ba3 (diff)
only send a sensitivity update command when the settings have changed.
Diffstat (limited to 'sys/dev/pci')
-rw-r--r--sys/dev/pci/if_iwn.c42
1 files changed, 27 insertions, 15 deletions
diff --git a/sys/dev/pci/if_iwn.c b/sys/dev/pci/if_iwn.c
index f4e15adaee2..a15bf5546e6 100644
--- a/sys/dev/pci/if_iwn.c
+++ b/sys/dev/pci/if_iwn.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_iwn.c,v 1.6 2007/09/07 20:02:54 damien Exp $ */
+/* $OpenBSD: if_iwn.c,v 1.7 2007/09/10 17:55:48 damien Exp $ */
/*-
* Copyright (c) 2007
@@ -2572,8 +2572,7 @@ iwn_get_temperature(struct iwn_softc *sc)
return 0;
/* sign-extend 23-bit R4 value to 32-bit */
- if (r4 & (1 << 23))
- r4 |= ~((1 << 23) - 1);
+ r4 = (r4 << 8) >> 8;
/* compute temperature */
temp = (259 * (r4 - r2)) / (r3 - r1);
temp = (temp * 97) / 100 + 8;
@@ -2682,10 +2681,22 @@ iwn_compute_differential_gain(struct iwn_softc *sc,
void
iwn_tune_sensitivity(struct iwn_softc *sc, const struct iwn_rx_stats *stats)
{
-#define inc_clip(val, inc, max) \
- if (((val) += (inc)) > (max)) (val) = (max)
-#define dec_clip(val, dec, min) \
- if (((val) -= (dec)) < (min)) (val) = (min)
+#define inc_clip(val, inc, max) \
+ if ((val) < (max)) { \
+ if ((val) < (max) - (inc)) \
+ (val) += (inc); \
+ else \
+ (val) = (max); \
+ needs_update = 1; \
+ }
+#define dec_clip(val, dec, min) \
+ if ((val) > (min)) { \
+ if ((val) > (min) + (dec)) \
+ (val) -= (dec); \
+ else \
+ (val) = (min); \
+ needs_update = 1; \
+ }
struct iwn_calib_state *calib = &sc->calib;
uint32_t val, rxena, fa;
@@ -2708,19 +2719,19 @@ iwn_tune_sensitivity(struct iwn_softc *sc, const struct iwn_rx_stats *stats)
if (fa > 50 * rxena) {
/* high false alarm count, decrease sensitivity */
+ DPRINTFN(2, ("OFDM high false alarm count: %u\n", fa));
inc_clip(calib->corr_ofdm_x1, 1, 140);
inc_clip(calib->corr_ofdm_mrc_x1, 1, 270);
inc_clip(calib->corr_ofdm_x4, 1, 120);
inc_clip(calib->corr_ofdm_mrc_x4, 1, 210);
- needs_update = 1;
} else if (fa < 5 * rxena) {
/* low false alarm count, increase sensitivity */
+ DPRINTFN(2, ("OFDM low false alarm count: %u\n", fa));
dec_clip(calib->corr_ofdm_x1, 1, 105);
dec_clip(calib->corr_ofdm_mrc_x1, 1, 220);
dec_clip(calib->corr_ofdm_x4, 1, 85);
dec_clip(calib->corr_ofdm_mrc_x4, 1, 170);
- needs_update = 1;
}
/* compute maximum noise among 3 antennas */
@@ -2772,13 +2783,13 @@ iwn_tune_sensitivity(struct iwn_softc *sc, const struct iwn_rx_stats *stats)
if (calib->energy_cck > 2)
dec_clip(calib->energy_cck, 2, energy_min);
}
- if (calib->corr_cck_x4 < 160)
+ if (calib->corr_cck_x4 < 160) {
calib->corr_cck_x4 = 161;
- else
+ needs_update = 1;
+ } else
inc_clip(calib->corr_cck_x4, 3, 200);
inc_clip(calib->corr_cck_mrc_x4, 3, 400);
- needs_update = 1;
} else if (fa < 5 * rxena) {
/* low false alarm count, increase sensitivity */
@@ -2792,7 +2803,6 @@ iwn_tune_sensitivity(struct iwn_softc *sc, const struct iwn_rx_stats *stats)
inc_clip(calib->energy_cck, 2, 97);
dec_clip(calib->corr_cck_x4, 3, 125);
dec_clip(calib->corr_cck_mrc_x4, 3, 200);
- needs_update = 1;
}
} else {
/* not worth to increase or decrease sensitivity */
@@ -2803,7 +2813,6 @@ iwn_tune_sensitivity(struct iwn_softc *sc, const struct iwn_rx_stats *stats)
if (calib->cck_state == IWN_CCK_STATE_HIFA) {
/* previous interval had many false alarms */
dec_clip(calib->energy_cck, 8, energy_min);
- needs_update = 1;
}
calib->cck_state = IWN_CCK_STATE_INIT;
}
@@ -2837,7 +2846,10 @@ iwn_send_sensitivity(struct iwn_softc *sc)
cmd.corr_barker = letoh16(190);
cmd.corr_barker_mrc = letoh16(390);
- DPRINTFN(2, ("setting sensitivity\n"));
+ DPRINTFN(2, ("setting sensitivity %d/%d/%d/%d/%d/%d/%d\n",
+ calib->corr_ofdm_x1, calib->corr_ofdm_mrc_x1, calib->corr_ofdm_x4,
+ calib->corr_ofdm_mrc_x4, calib->corr_cck_x4,
+ calib->corr_cck_mrc_x4, calib->energy_cck));
return iwn_cmd(sc, IWN_SENSITIVITY, &cmd, sizeof cmd, 1);
}