diff options
author | Ivo van Doorn <ivdoorn@gmail.com> | 2008-08-29 15:05:45 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2008-08-29 16:24:12 -0400 |
commit | 2af0a570b45ec315f364ea2c8a6d072cfcaa9d32 (patch) | |
tree | c3570f4c9bb0d24bef857977e5251b04309b95ad /drivers/net/wireless/rt2x00 | |
parent | 2575c11d6ee7266f0f035e55c5056b36597cd336 (diff) |
rt2x00: Initialize txop during conf_tx() callback
The txop parameter is supported by rt61pci and rt73usb,
and thus should be written to the register instead
of using the fixed value set during initialization.
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')
-rw-r--r-- | drivers/net/wireless/rt2x00/rt2x00mac.c | 5 | ||||
-rw-r--r-- | drivers/net/wireless/rt2x00/rt2x00queue.c | 1 | ||||
-rw-r--r-- | drivers/net/wireless/rt2x00/rt2x00queue.h | 2 | ||||
-rw-r--r-- | drivers/net/wireless/rt2x00/rt61pci.c | 69 | ||||
-rw-r--r-- | drivers/net/wireless/rt2x00/rt73usb.c | 69 |
5 files changed, 122 insertions, 24 deletions
diff --git a/drivers/net/wireless/rt2x00/rt2x00mac.c b/drivers/net/wireless/rt2x00/rt2x00mac.c index 64292c227c96..56829fad3471 100644 --- a/drivers/net/wireless/rt2x00/rt2x00mac.c +++ b/drivers/net/wireless/rt2x00/rt2x00mac.c | |||
@@ -666,10 +666,11 @@ int rt2x00mac_conf_tx(struct ieee80211_hw *hw, u16 queue_idx, | |||
666 | queue->cw_max = 10; /* cw_min: 2^10 = 1024. */ | 666 | queue->cw_max = 10; /* cw_min: 2^10 = 1024. */ |
667 | 667 | ||
668 | queue->aifs = params->aifs; | 668 | queue->aifs = params->aifs; |
669 | queue->txop = params->txop; | ||
669 | 670 | ||
670 | INFO(rt2x00dev, | 671 | INFO(rt2x00dev, |
671 | "Configured TX queue %d - CWmin: %d, CWmax: %d, Aifs: %d.\n", | 672 | "Configured TX queue %d - CWmin: %d, CWmax: %d, Aifs: %d, TXop: %d.\n", |
672 | queue_idx, queue->cw_min, queue->cw_max, queue->aifs); | 673 | queue_idx, queue->cw_min, queue->cw_max, queue->aifs, queue->txop); |
673 | 674 | ||
674 | return 0; | 675 | return 0; |
675 | } | 676 | } |
diff --git a/drivers/net/wireless/rt2x00/rt2x00queue.c b/drivers/net/wireless/rt2x00/rt2x00queue.c index 2822684c505e..a5e965068c83 100644 --- a/drivers/net/wireless/rt2x00/rt2x00queue.c +++ b/drivers/net/wireless/rt2x00/rt2x00queue.c | |||
@@ -736,6 +736,7 @@ static void rt2x00queue_init(struct rt2x00_dev *rt2x00dev, | |||
736 | 736 | ||
737 | queue->rt2x00dev = rt2x00dev; | 737 | queue->rt2x00dev = rt2x00dev; |
738 | queue->qid = qid; | 738 | queue->qid = qid; |
739 | queue->txop = 0; | ||
739 | queue->aifs = 2; | 740 | queue->aifs = 2; |
740 | queue->cw_min = 5; | 741 | queue->cw_min = 5; |
741 | queue->cw_max = 10; | 742 | queue->cw_max = 10; |
diff --git a/drivers/net/wireless/rt2x00/rt2x00queue.h b/drivers/net/wireless/rt2x00/rt2x00queue.h index 37f3f98d58a2..654fa0c624d3 100644 --- a/drivers/net/wireless/rt2x00/rt2x00queue.h +++ b/drivers/net/wireless/rt2x00/rt2x00queue.h | |||
@@ -368,6 +368,7 @@ enum queue_index { | |||
368 | * @length: Number of frames in queue. | 368 | * @length: Number of frames in queue. |
369 | * @index: Index pointers to entry positions in the queue, | 369 | * @index: Index pointers to entry positions in the queue, |
370 | * use &enum queue_index to get a specific index field. | 370 | * use &enum queue_index to get a specific index field. |
371 | * @txop: maximum burst time. | ||
371 | * @aifs: The aifs value for outgoing frames (field ignored in RX queue). | 372 | * @aifs: The aifs value for outgoing frames (field ignored in RX queue). |
372 | * @cw_min: The cw min value for outgoing frames (field ignored in RX queue). | 373 | * @cw_min: The cw min value for outgoing frames (field ignored in RX queue). |
373 | * @cw_max: The cw max value for outgoing frames (field ignored in RX queue). | 374 | * @cw_max: The cw max value for outgoing frames (field ignored in RX queue). |
@@ -387,6 +388,7 @@ struct data_queue { | |||
387 | unsigned short length; | 388 | unsigned short length; |
388 | unsigned short index[Q_INDEX_MAX]; | 389 | unsigned short index[Q_INDEX_MAX]; |
389 | 390 | ||
391 | unsigned short txop; | ||
390 | unsigned short aifs; | 392 | unsigned short aifs; |
391 | unsigned short cw_min; | 393 | unsigned short cw_min; |
392 | unsigned short cw_max; | 394 | unsigned short cw_max; |
diff --git a/drivers/net/wireless/rt2x00/rt61pci.c b/drivers/net/wireless/rt2x00/rt61pci.c index 9d27ce0e54fe..52537101c908 100644 --- a/drivers/net/wireless/rt2x00/rt61pci.c +++ b/drivers/net/wireless/rt2x00/rt61pci.c | |||
@@ -1478,16 +1478,6 @@ static int rt61pci_init_registers(struct rt2x00_dev *rt2x00dev) | |||
1478 | 1478 | ||
1479 | rt2x00pci_register_write(rt2x00dev, M2H_CMD_DONE_CSR, 0xffffffff); | 1479 | rt2x00pci_register_write(rt2x00dev, M2H_CMD_DONE_CSR, 0xffffffff); |
1480 | 1480 | ||
1481 | rt2x00pci_register_read(rt2x00dev, AC_TXOP_CSR0, ®); | ||
1482 | rt2x00_set_field32(®, AC_TXOP_CSR0_AC0_TX_OP, 0); | ||
1483 | rt2x00_set_field32(®, AC_TXOP_CSR0_AC1_TX_OP, 0); | ||
1484 | rt2x00pci_register_write(rt2x00dev, AC_TXOP_CSR0, reg); | ||
1485 | |||
1486 | rt2x00pci_register_read(rt2x00dev, AC_TXOP_CSR1, ®); | ||
1487 | rt2x00_set_field32(®, AC_TXOP_CSR1_AC2_TX_OP, 192); | ||
1488 | rt2x00_set_field32(®, AC_TXOP_CSR1_AC3_TX_OP, 48); | ||
1489 | rt2x00pci_register_write(rt2x00dev, AC_TXOP_CSR1, reg); | ||
1490 | |||
1491 | /* | 1481 | /* |
1492 | * Clear all beacons | 1482 | * Clear all beacons |
1493 | * For the Beacon base registers we only need to clear | 1483 | * For the Beacon base registers we only need to clear |
@@ -2652,6 +2642,63 @@ static int rt61pci_set_retry_limit(struct ieee80211_hw *hw, | |||
2652 | return 0; | 2642 | return 0; |
2653 | } | 2643 | } |
2654 | 2644 | ||
2645 | static int rt61pci_conf_tx(struct ieee80211_hw *hw, u16 queue_idx, | ||
2646 | const struct ieee80211_tx_queue_params *params) | ||
2647 | { | ||
2648 | struct rt2x00_dev *rt2x00dev = hw->priv; | ||
2649 | struct data_queue *queue; | ||
2650 | struct rt2x00_field32 field; | ||
2651 | int retval; | ||
2652 | u32 reg; | ||
2653 | |||
2654 | /* | ||
2655 | * First pass the configuration through rt2x00lib, that will | ||
2656 | * update the queue settings and validate the input. After that | ||
2657 | * we are free to update the registers based on the value | ||
2658 | * in the queue parameter. | ||
2659 | */ | ||
2660 | retval = rt2x00mac_conf_tx(hw, queue_idx, params); | ||
2661 | if (retval) | ||
2662 | return retval; | ||
2663 | |||
2664 | queue = rt2x00queue_get_queue(rt2x00dev, queue_idx); | ||
2665 | |||
2666 | /* Update WMM TXOP register */ | ||
2667 | if (queue_idx < 2) { | ||
2668 | field.bit_offset = queue_idx * 16; | ||
2669 | field.bit_mask = 0xffff << field.bit_offset; | ||
2670 | |||
2671 | rt2x00pci_register_read(rt2x00dev, AC_TXOP_CSR0, ®); | ||
2672 | rt2x00_set_field32(®, field, queue->txop); | ||
2673 | rt2x00pci_register_write(rt2x00dev, AC_TXOP_CSR0, reg); | ||
2674 | } else if (queue_idx < 4) { | ||
2675 | field.bit_offset = (queue_idx - 2) * 16; | ||
2676 | field.bit_mask = 0xffff << field.bit_offset; | ||
2677 | |||
2678 | rt2x00pci_register_read(rt2x00dev, AC_TXOP_CSR1, ®); | ||
2679 | rt2x00_set_field32(®, field, queue->txop); | ||
2680 | rt2x00pci_register_write(rt2x00dev, AC_TXOP_CSR1, reg); | ||
2681 | } | ||
2682 | |||
2683 | /* Update WMM registers */ | ||
2684 | field.bit_offset = queue_idx * 4; | ||
2685 | field.bit_mask = 0xf << field.bit_offset; | ||
2686 | |||
2687 | rt2x00pci_register_read(rt2x00dev, AIFSN_CSR, ®); | ||
2688 | rt2x00_set_field32(®, field, queue->aifs); | ||
2689 | rt2x00pci_register_write(rt2x00dev, AIFSN_CSR, reg); | ||
2690 | |||
2691 | rt2x00pci_register_read(rt2x00dev, CWMIN_CSR, ®); | ||
2692 | rt2x00_set_field32(®, field, queue->cw_min); | ||
2693 | rt2x00pci_register_write(rt2x00dev, CWMIN_CSR, reg); | ||
2694 | |||
2695 | rt2x00pci_register_read(rt2x00dev, CWMAX_CSR, ®); | ||
2696 | rt2x00_set_field32(®, field, queue->cw_max); | ||
2697 | rt2x00pci_register_write(rt2x00dev, CWMAX_CSR, reg); | ||
2698 | |||
2699 | return 0; | ||
2700 | } | ||
2701 | |||
2655 | static u64 rt61pci_get_tsf(struct ieee80211_hw *hw) | 2702 | static u64 rt61pci_get_tsf(struct ieee80211_hw *hw) |
2656 | { | 2703 | { |
2657 | struct rt2x00_dev *rt2x00dev = hw->priv; | 2704 | struct rt2x00_dev *rt2x00dev = hw->priv; |
@@ -2679,7 +2726,7 @@ static const struct ieee80211_ops rt61pci_mac80211_ops = { | |||
2679 | .get_stats = rt2x00mac_get_stats, | 2726 | .get_stats = rt2x00mac_get_stats, |
2680 | .set_retry_limit = rt61pci_set_retry_limit, | 2727 | .set_retry_limit = rt61pci_set_retry_limit, |
2681 | .bss_info_changed = rt2x00mac_bss_info_changed, | 2728 | .bss_info_changed = rt2x00mac_bss_info_changed, |
2682 | .conf_tx = rt2x00mac_conf_tx, | 2729 | .conf_tx = rt61pci_conf_tx, |
2683 | .get_tx_stats = rt2x00mac_get_tx_stats, | 2730 | .get_tx_stats = rt2x00mac_get_tx_stats, |
2684 | .get_tsf = rt61pci_get_tsf, | 2731 | .get_tsf = rt61pci_get_tsf, |
2685 | }; | 2732 | }; |
diff --git a/drivers/net/wireless/rt2x00/rt73usb.c b/drivers/net/wireless/rt2x00/rt73usb.c index f58fd059c9a0..636b4e0d0ef5 100644 --- a/drivers/net/wireless/rt2x00/rt73usb.c +++ b/drivers/net/wireless/rt2x00/rt73usb.c | |||
@@ -1277,16 +1277,6 @@ static int rt73usb_init_registers(struct rt2x00_dev *rt2x00dev) | |||
1277 | rt73usb_register_write(rt2x00dev, PHY_CSR6, 0x00080606); | 1277 | rt73usb_register_write(rt2x00dev, PHY_CSR6, 0x00080606); |
1278 | rt73usb_register_write(rt2x00dev, PHY_CSR7, 0x00000408); | 1278 | rt73usb_register_write(rt2x00dev, PHY_CSR7, 0x00000408); |
1279 | 1279 | ||
1280 | rt73usb_register_read(rt2x00dev, AC_TXOP_CSR0, ®); | ||
1281 | rt2x00_set_field32(®, AC_TXOP_CSR0_AC0_TX_OP, 0); | ||
1282 | rt2x00_set_field32(®, AC_TXOP_CSR0_AC1_TX_OP, 0); | ||
1283 | rt73usb_register_write(rt2x00dev, AC_TXOP_CSR0, reg); | ||
1284 | |||
1285 | rt73usb_register_read(rt2x00dev, AC_TXOP_CSR1, ®); | ||
1286 | rt2x00_set_field32(®, AC_TXOP_CSR1_AC2_TX_OP, 192); | ||
1287 | rt2x00_set_field32(®, AC_TXOP_CSR1_AC3_TX_OP, 48); | ||
1288 | rt73usb_register_write(rt2x00dev, AC_TXOP_CSR1, reg); | ||
1289 | |||
1290 | rt73usb_register_read(rt2x00dev, MAC_CSR9, ®); | 1280 | rt73usb_register_read(rt2x00dev, MAC_CSR9, ®); |
1291 | rt2x00_set_field32(®, MAC_CSR9_CW_SELECT, 0); | 1281 | rt2x00_set_field32(®, MAC_CSR9_CW_SELECT, 0); |
1292 | rt73usb_register_write(rt2x00dev, MAC_CSR9, reg); | 1282 | rt73usb_register_write(rt2x00dev, MAC_CSR9, reg); |
@@ -2246,6 +2236,63 @@ static int rt73usb_set_retry_limit(struct ieee80211_hw *hw, | |||
2246 | return 0; | 2236 | return 0; |
2247 | } | 2237 | } |
2248 | 2238 | ||
2239 | static int rt73usb_conf_tx(struct ieee80211_hw *hw, u16 queue_idx, | ||
2240 | const struct ieee80211_tx_queue_params *params) | ||
2241 | { | ||
2242 | struct rt2x00_dev *rt2x00dev = hw->priv; | ||
2243 | struct data_queue *queue; | ||
2244 | struct rt2x00_field32 field; | ||
2245 | int retval; | ||
2246 | u32 reg; | ||
2247 | |||
2248 | /* | ||
2249 | * First pass the configuration through rt2x00lib, that will | ||
2250 | * update the queue settings and validate the input. After that | ||
2251 | * we are free to update the registers based on the value | ||
2252 | * in the queue parameter. | ||
2253 | */ | ||
2254 | retval = rt2x00mac_conf_tx(hw, queue_idx, params); | ||
2255 | if (retval) | ||
2256 | return retval; | ||
2257 | |||
2258 | queue = rt2x00queue_get_queue(rt2x00dev, queue_idx); | ||
2259 | |||
2260 | /* Update WMM TXOP register */ | ||
2261 | if (queue_idx < 2) { | ||
2262 | field.bit_offset = queue_idx * 16; | ||
2263 | field.bit_mask = 0xffff << field.bit_offset; | ||
2264 | |||
2265 | rt73usb_register_read(rt2x00dev, AC_TXOP_CSR0, ®); | ||
2266 | rt2x00_set_field32(®, field, queue->txop); | ||
2267 | rt73usb_register_write(rt2x00dev, AC_TXOP_CSR0, reg); | ||
2268 | } else if (queue_idx < 4) { | ||
2269 | field.bit_offset = (queue_idx - 2) * 16; | ||
2270 | field.bit_mask = 0xffff << field.bit_offset; | ||
2271 | |||
2272 | rt73usb_register_read(rt2x00dev, AC_TXOP_CSR1, ®); | ||
2273 | rt2x00_set_field32(®, field, queue->txop); | ||
2274 | rt73usb_register_write(rt2x00dev, AC_TXOP_CSR1, reg); | ||
2275 | } | ||
2276 | |||
2277 | /* Update WMM registers */ | ||
2278 | field.bit_offset = queue_idx * 4; | ||
2279 | field.bit_mask = 0xf << field.bit_offset; | ||
2280 | |||
2281 | rt73usb_register_read(rt2x00dev, AIFSN_CSR, ®); | ||
2282 | rt2x00_set_field32(®, field, queue->aifs); | ||
2283 | rt73usb_register_write(rt2x00dev, AIFSN_CSR, reg); | ||
2284 | |||
2285 | rt73usb_register_read(rt2x00dev, CWMIN_CSR, ®); | ||
2286 | rt2x00_set_field32(®, field, queue->cw_min); | ||
2287 | rt73usb_register_write(rt2x00dev, CWMIN_CSR, reg); | ||
2288 | |||
2289 | rt73usb_register_read(rt2x00dev, CWMAX_CSR, ®); | ||
2290 | rt2x00_set_field32(®, field, queue->cw_max); | ||
2291 | rt73usb_register_write(rt2x00dev, CWMAX_CSR, reg); | ||
2292 | |||
2293 | return 0; | ||
2294 | } | ||
2295 | |||
2249 | #if 0 | 2296 | #if 0 |
2250 | /* | 2297 | /* |
2251 | * Mac80211 demands get_tsf must be atomic. | 2298 | * Mac80211 demands get_tsf must be atomic. |
@@ -2283,7 +2330,7 @@ static const struct ieee80211_ops rt73usb_mac80211_ops = { | |||
2283 | .get_stats = rt2x00mac_get_stats, | 2330 | .get_stats = rt2x00mac_get_stats, |
2284 | .set_retry_limit = rt73usb_set_retry_limit, | 2331 | .set_retry_limit = rt73usb_set_retry_limit, |
2285 | .bss_info_changed = rt2x00mac_bss_info_changed, | 2332 | .bss_info_changed = rt2x00mac_bss_info_changed, |
2286 | .conf_tx = rt2x00mac_conf_tx, | 2333 | .conf_tx = rt73usb_conf_tx, |
2287 | .get_tx_stats = rt2x00mac_get_tx_stats, | 2334 | .get_tx_stats = rt2x00mac_get_tx_stats, |
2288 | .get_tsf = rt73usb_get_tsf, | 2335 | .get_tsf = rt73usb_get_tsf, |
2289 | }; | 2336 | }; |