diff options
author | Ivo van Doorn <ivdoorn@gmail.com> | 2009-01-17 14:42:58 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2009-01-29 16:00:46 -0500 |
commit | 5e790023620ee02486fd64c7e5a6115ce004495d (patch) | |
tree | b2cf06ad1b846c191fd2cf240c7f35cd4cb5ad55 /drivers/net/wireless/rt2x00/rt73usb.c | |
parent | 4e54c711b42c3cc8da8a3fdcde3407b86d67ebcc (diff) |
rt2x00: conf_tx() only need register access for WMM queues
conf_tx() in rt61pci and rt73usb only have to check once
if the queue_idx indicates a non-WMM queue and break of
the function immediately if that is the case.
Only the WMM queues need to have the TX configuration written
to the registers.
Signed-off-by: Ivo van Doorn <IvDoorn@gmail.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/rt2x00/rt73usb.c')
-rw-r--r-- | drivers/net/wireless/rt2x00/rt73usb.c | 30 |
1 files changed, 15 insertions, 15 deletions
diff --git a/drivers/net/wireless/rt2x00/rt73usb.c b/drivers/net/wireless/rt2x00/rt73usb.c index 961f9f9352d..60c43c11bc1 100644 --- a/drivers/net/wireless/rt2x00/rt73usb.c +++ b/drivers/net/wireless/rt2x00/rt73usb.c | |||
@@ -2180,6 +2180,7 @@ static int rt73usb_conf_tx(struct ieee80211_hw *hw, u16 queue_idx, | |||
2180 | struct rt2x00_field32 field; | 2180 | struct rt2x00_field32 field; |
2181 | int retval; | 2181 | int retval; |
2182 | u32 reg; | 2182 | u32 reg; |
2183 | u32 offset; | ||
2183 | 2184 | ||
2184 | /* | 2185 | /* |
2185 | * First pass the configuration through rt2x00lib, that will | 2186 | * First pass the configuration through rt2x00lib, that will |
@@ -2191,24 +2192,23 @@ static int rt73usb_conf_tx(struct ieee80211_hw *hw, u16 queue_idx, | |||
2191 | if (retval) | 2192 | if (retval) |
2192 | return retval; | 2193 | return retval; |
2193 | 2194 | ||
2195 | /* | ||
2196 | * We only need to perform additional register initialization | ||
2197 | * for WMM queues/ | ||
2198 | */ | ||
2199 | if (queue_idx >= 4) | ||
2200 | return 0; | ||
2201 | |||
2194 | queue = rt2x00queue_get_queue(rt2x00dev, queue_idx); | 2202 | queue = rt2x00queue_get_queue(rt2x00dev, queue_idx); |
2195 | 2203 | ||
2196 | /* Update WMM TXOP register */ | 2204 | /* Update WMM TXOP register */ |
2197 | if (queue_idx < 2) { | 2205 | offset = AC_TXOP_CSR0 + (sizeof(u32) * (!!(queue_idx & 2))); |
2198 | field.bit_offset = queue_idx * 16; | 2206 | field.bit_offset = (queue_idx & 1) * 16; |
2199 | field.bit_mask = 0xffff << field.bit_offset; | 2207 | field.bit_mask = 0xffff << field.bit_offset; |
2200 | 2208 | ||
2201 | rt2x00usb_register_read(rt2x00dev, AC_TXOP_CSR0, ®); | 2209 | rt2x00usb_register_read(rt2x00dev, offset, ®); |
2202 | rt2x00_set_field32(®, field, queue->txop); | 2210 | rt2x00_set_field32(®, field, queue->txop); |
2203 | rt2x00usb_register_write(rt2x00dev, AC_TXOP_CSR0, reg); | 2211 | rt2x00usb_register_write(rt2x00dev, offset, reg); |
2204 | } else if (queue_idx < 4) { | ||
2205 | field.bit_offset = (queue_idx - 2) * 16; | ||
2206 | field.bit_mask = 0xffff << field.bit_offset; | ||
2207 | |||
2208 | rt2x00usb_register_read(rt2x00dev, AC_TXOP_CSR1, ®); | ||
2209 | rt2x00_set_field32(®, field, queue->txop); | ||
2210 | rt2x00usb_register_write(rt2x00dev, AC_TXOP_CSR1, reg); | ||
2211 | } | ||
2212 | 2212 | ||
2213 | /* Update WMM registers */ | 2213 | /* Update WMM registers */ |
2214 | field.bit_offset = queue_idx * 4; | 2214 | field.bit_offset = queue_idx * 4; |