mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-17 23:36:12 +07:00
ath5k: optimize ath5k_hw_calibration_poll
Optimize ath5k_hw_calibration_poll() since it is called on every singe interrupt. Signed-off-by: Bruno Randolf <br1@einfach.org> Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
parent
e65e1d7713
commit
a9167f9642
@ -1100,7 +1100,7 @@ struct ath5k_hw {
|
|||||||
s32 ah_noise_floor;
|
s32 ah_noise_floor;
|
||||||
|
|
||||||
/* Calibration timestamp */
|
/* Calibration timestamp */
|
||||||
unsigned long ah_cal_tstamp;
|
unsigned long ah_cal_next_full;
|
||||||
|
|
||||||
/* Calibration mask */
|
/* Calibration mask */
|
||||||
u8 ah_cal_mask;
|
u8 ah_cal_mask;
|
||||||
|
@ -1105,22 +1105,14 @@ int ath5k_hw_channel(struct ath5k_hw *ah, struct ieee80211_channel *channel)
|
|||||||
void
|
void
|
||||||
ath5k_hw_calibration_poll(struct ath5k_hw *ah)
|
ath5k_hw_calibration_poll(struct ath5k_hw *ah)
|
||||||
{
|
{
|
||||||
/* Calibration interval in jiffies */
|
if (time_is_before_eq_jiffies(ah->ah_cal_next_full)) {
|
||||||
unsigned long cal_intval;
|
ah->ah_cal_next_full = jiffies +
|
||||||
|
msecs_to_jiffies(ATH5K_TUNE_CALIBRATION_INTERVAL_FULL);
|
||||||
cal_intval = msecs_to_jiffies(ATH5K_TUNE_CALIBRATION_INTERVAL_FULL);
|
|
||||||
|
|
||||||
/* Initialize timestamp if needed */
|
|
||||||
if (!ah->ah_cal_tstamp)
|
|
||||||
ah->ah_cal_tstamp = jiffies;
|
|
||||||
|
|
||||||
/* For now we always do full calibration
|
|
||||||
* Mark software interrupt mask and fire software
|
|
||||||
* interrupt (bit gets auto-cleared) */
|
|
||||||
if (time_is_before_eq_jiffies(ah->ah_cal_tstamp + cal_intval)) {
|
|
||||||
ah->ah_cal_tstamp = jiffies;
|
|
||||||
tasklet_schedule(&ah->ah_sc->calib);
|
tasklet_schedule(&ah->ah_sc->calib);
|
||||||
}
|
}
|
||||||
|
/* we could use SWI to generate enough interrupts to meet our
|
||||||
|
* calibration interval requirements, if necessary:
|
||||||
|
* AR5K_REG_ENABLE_BITS(ah, AR5K_CR, AR5K_CR_SWI); */
|
||||||
}
|
}
|
||||||
|
|
||||||
static int sign_extend(int val, const int nbits)
|
static int sign_extend(int val, const int nbits)
|
||||||
|
Loading…
Reference in New Issue
Block a user