Changeset 18444


Ignore:
Timestamp:
2009-11-18T04:48:55+01:00 (8 years ago)
Author:
nbd
Message:

ath9k: split up and adjust rc cleanup patch according to upstream feedback, also fix tx status reporting for minstrel compatibility

Location:
trunk/package/mac80211/patches
Files:
1 added
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/package/mac80211/patches/560-ath9k_rate_control_api.patch

    r18436 r18444  
    11--- a/drivers/net/wireless/ath/ath9k/rc.c 
    22+++ b/drivers/net/wireless/ath/ath9k/rc.c 
    3 @@ -19,133 +19,92 @@ 
     3@@ -19,6 +19,7 @@ 
    44  
    55 static const struct ath_rate_table ar5416_11na_ratetable = { 
     
    88        { 
    99                { VALID, VALID, WLAN_RC_PHY_OFDM, 6000, /* 6 Mb */ 
    10 -                       5400, 0x0b, 0x00, 12, 
    11 -                       0, 0, 0, 0, 0, 0 }, 
    12 +                       5400, 0, 12, 0, 0, 0, 0, 0 }, 
    13                 { VALID, VALID, WLAN_RC_PHY_OFDM, 9000, /* 9 Mb */ 
    14 -                       7800,  0x0f, 0x00, 18, 
    15 -                       0, 1, 1, 1, 1, 0 }, 
    16 +                       7800,  1, 18, 0, 1, 1, 1, 1 }, 
    17                 { VALID, VALID, WLAN_RC_PHY_OFDM, 12000, /* 12 Mb */ 
    18 -                       10000, 0x0a, 0x00, 24, 
    19 -                       2, 2, 2, 2, 2, 0 }, 
    20 +                       10000, 2, 24, 2, 2, 2, 2, 2 }, 
    21                 { VALID, VALID, WLAN_RC_PHY_OFDM, 18000, /* 18 Mb */ 
    22 -                       13900, 0x0e, 0x00, 36, 
    23 -                       2,  3, 3, 3, 3, 0 }, 
    24 +                       13900, 3, 36, 2, 3, 3, 3, 3 }, 
    25                 { VALID, VALID, WLAN_RC_PHY_OFDM, 24000, /* 24 Mb */ 
    26 -                       17300, 0x09, 0x00, 48, 
    27 -                       4,  4, 4, 4, 4, 0 }, 
    28 +                       17300, 4, 48, 4, 4, 4, 4, 4 }, 
    29                 { VALID, VALID, WLAN_RC_PHY_OFDM, 36000, /* 36 Mb */ 
    30 -                       23000, 0x0d, 0x00, 72, 
    31 -                       4,  5, 5, 5, 5, 0 }, 
    32 +                       23000, 5, 72, 4, 5, 5, 5, 5 }, 
    33                 { VALID, VALID, WLAN_RC_PHY_OFDM, 48000, /* 48 Mb */ 
    34 -                       27400, 0x08, 0x00, 96, 
    35 -                       4,  6, 6, 6, 6, 0 }, 
    36 +                       27400, 6, 96, 4, 6, 6, 6, 6 }, 
    37                 { VALID, VALID, WLAN_RC_PHY_OFDM, 54000, /* 54 Mb */ 
    38 -                       29300, 0x0c, 0x00, 108, 
    39 -                       4,  7, 7, 7, 7, 0 }, 
    40 +                       29300, 7, 108, 4, 7, 7, 7, 7 }, 
    41                 { VALID_2040, VALID_2040, WLAN_RC_PHY_HT_20_SS, 6500, /* 6.5 Mb */ 
    42 -                       6400, 0x80, 0x00, 0, 
    43 -                       0, 8, 24, 8, 24, 3216 }, 
    44 +                       6400, 0, 0, 0, 8, 24, 8, 24 }, 
    45                 { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 13000, /* 13 Mb */ 
    46 -                       12700, 0x81, 0x00, 1, 
    47 -                       2, 9, 25, 9, 25, 6434 }, 
    48 +                       12700, 1, 1, 2, 9, 25, 9, 25 }, 
    49                 { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 19500, /* 19.5 Mb */ 
    50 -                       18800, 0x82, 0x00, 2, 
    51 -                       2, 10, 26, 10, 26, 9650 }, 
    52 +                       18800, 2, 2, 2, 10, 26, 10, 26 }, 
    53                 { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 26000, /* 26 Mb */ 
    54 -                       25000, 0x83, 0x00, 3, 
    55 -                       4,  11, 27, 11, 27, 12868 }, 
    56 +                       25000, 3, 3, 4, 11, 27, 11, 27 }, 
    57                 { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 39000, /* 39 Mb */ 
    58 -                       36700, 0x84, 0x00, 4, 
    59 -                       4,  12, 28, 12, 28, 19304 }, 
    60 +                       36700, 4, 4, 4, 12, 28, 12, 28 }, 
    61                 { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 52000, /* 52 Mb */ 
    62 -                       48100, 0x85, 0x00, 5, 
    63 -                       4,  13, 29, 13, 29, 25740 }, 
    64 +                       48100, 5, 5, 4, 13, 29, 13, 29 }, 
    65                 { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 58500, /* 58.5 Mb */ 
    66 -                       53500, 0x86, 0x00, 6, 
    67 -                       4,  14, 30, 14, 30,  28956 }, 
    68 +                       53500, 6, 6, 4, 14, 30, 14, 30 }, 
    69                 { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 65000, /* 65 Mb */ 
    70 -                       59000, 0x87, 0x00, 7, 
    71 -                       4,  15, 31, 15, 32, 32180 }, 
    72 +                       59000, 7, 7, 4, 15, 31, 15, 32 }, 
    73                 { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 13000, /* 13 Mb */ 
    74 -                       12700, 0x88, 0x00, 
    75 -                       8, 3, 16, 33, 16, 33, 6430 }, 
    76 +                       12700, 8, 8, 3, 16, 33, 16, 33 }, 
    77                 { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 26000, /* 26 Mb */ 
    78 -                       24800, 0x89, 0x00, 9, 
    79 -                       2, 17, 34, 17, 34, 12860 }, 
    80 +                       24800, 9, 9, 2, 17, 34, 17, 34 }, 
    81                 { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 39000, /* 39 Mb */ 
    82 -                       36600, 0x8a, 0x00, 10, 
    83 -                       2, 18, 35, 18, 35, 19300 }, 
    84 +                       36600, 10, 10, 2, 18, 35, 18, 35 }, 
    85                 { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 52000, /* 52 Mb */ 
    86 -                       48100, 0x8b, 0x00, 11, 
    87 -                       4,  19, 36, 19, 36, 25736 }, 
    88 +                       48100, 11, 11, 4, 19, 36, 19, 36 }, 
    89                 { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 78000, /* 78 Mb */ 
    90 -                       69500, 0x8c, 0x00, 12, 
    91 -                       4,  20, 37, 20, 37, 38600 }, 
    92 +                       69500, 12, 12, 4, 20, 37, 20, 37 }, 
    93                 { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 104000, /* 104 Mb */ 
    94 -                       89500, 0x8d, 0x00, 13, 
    95 -                       4,  21, 38, 21, 38, 51472 }, 
    96 +                       89500, 13, 13, 4, 21, 38, 21, 38 }, 
    97                 { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 117000, /* 117 Mb */ 
    98 -                       98900, 0x8e, 0x00, 14, 
    99 -                       4,  22, 39, 22, 39, 57890 }, 
    100 +                       98900, 14, 14, 4, 22, 39, 22, 39 }, 
    101                 { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 130000, /* 130 Mb */ 
    102 -                       108300, 0x8f, 0x00, 15, 
    103 -                       4,  23, 40, 23, 41, 64320 }, 
    104 +                       108300, 15, 15, 4, 23, 40, 23, 41 }, 
    105                 { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 13500, /* 13.5 Mb */ 
    106 -                       13200, 0x80, 0x00, 0, 
    107 -                       0, 8, 24, 24, 24, 6684 }, 
    108 +                       13200, 0, 0, 0, 8, 24, 24, 24 }, 
    109                 { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 27500, /* 27.0 Mb */ 
    110 -                       25900, 0x81, 0x00, 1, 
    111 -                       2, 9, 25, 25, 25, 13368 }, 
    112 +                       25900, 1, 1, 2, 9, 25, 25, 25 }, 
    113                 { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 40500, /* 40.5 Mb */ 
    114 -                       38600, 0x82, 0x00, 2, 
    115 -                       2, 10, 26, 26, 26, 20052 }, 
    116 +                       38600, 2, 2, 2, 10, 26, 26, 26 }, 
    117                 { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 54000, /* 54 Mb */ 
    118 -                       49800, 0x83, 0x00, 3, 
    119 -                       4,  11, 27, 27, 27, 26738 }, 
    120 +                       49800, 3, 3, 4, 11, 27, 27, 27 }, 
    121                 { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 81500, /* 81 Mb */ 
    122 -                       72200, 0x84, 0x00, 4, 
    123 -                       4,  12, 28, 28, 28, 40104 }, 
    124 +                       72200, 4, 4, 4, 12, 28, 28, 28 }, 
    125                 { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 108000, /* 108 Mb */ 
    126 -                       92900, 0x85, 0x00, 5, 
    127 -                       4,  13, 29, 29, 29, 53476 }, 
    128 +                       92900, 5, 5, 4, 13, 29, 29, 29 }, 
    129                 { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 121500, /* 121.5 Mb */ 
    130 -                       102700, 0x86, 0x00, 6, 
    131 -                       4,  14, 30, 30, 30, 60156 }, 
    132 +                       102700, 6, 6, 4, 14, 30, 30, 30 }, 
    133                 { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 135000, /* 135 Mb */ 
    134 -                       112000, 0x87, 0x00, 7, 
    135 -                       4,  15, 31, 32, 32, 66840 }, 
    136 +                       112000, 7, 7, 4, 15, 31, 32, 32 }, 
    137                 { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS_HGI, 150000, /* 150 Mb */ 
    138 -                       122000, 0x87, 0x00, 7, 
    139 -                       4,  15, 31, 32, 32, 74200 }, 
    140 +                       122000, 7, 7, 4, 15, 31, 32, 32 }, 
    141                 { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 27000, /* 27 Mb */ 
    142 -                       25800, 0x88, 0x00, 8, 
    143 -                       0, 16, 33, 33, 33, 13360 }, 
    144 +                       25800, 8, 8, 0, 16, 33, 33, 33 }, 
    145                 { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 54000, /* 54 Mb */ 
    146 -                       49800, 0x89, 0x00, 9, 
    147 -                       2, 17, 34, 34, 34, 26720 }, 
    148 +                       49800, 9, 9, 2, 17, 34, 34, 34 }, 
    149                 { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 81000, /* 81 Mb */ 
    150 -                       71900, 0x8a, 0x00, 10, 
    151 -                       2, 18, 35, 35, 35, 40080 }, 
    152 +                       71900, 10, 10, 2, 18, 35, 35, 35 }, 
    153                 { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 108000, /* 108 Mb */ 
    154 -                       92500, 0x8b, 0x00, 11, 
    155 -                       4,  19, 36, 36, 36, 53440 }, 
    156 +                       92500, 11, 11, 4, 19, 36, 36, 36 }, 
    157                 { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 162000, /* 162 Mb */ 
    158 -                       130300, 0x8c, 0x00, 12, 
    159 -                       4,  20, 37, 37, 37, 80160 }, 
    160 +                       130300, 12, 12, 4, 20, 37, 37, 37 }, 
    161                 { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 216000, /* 216 Mb */ 
    162 -                       162800, 0x8d, 0x00, 13, 
    163 -                       4,  21, 38, 38, 38, 106880 }, 
    164 +                       162800, 13, 13, 4, 21, 38, 38, 38 }, 
    165                 { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 243000, /* 243 Mb */ 
    166 -                       178200, 0x8e, 0x00, 14, 
    167 -                       4,  22, 39, 39, 39, 120240 }, 
    168 +                       178200, 14, 14, 4, 22, 39, 39, 39 }, 
    169                 { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 270000, /* 270 Mb */ 
    170 -                       192100, 0x8f, 0x00, 15, 
    171 -                       4,  23, 40, 41, 41, 133600 }, 
    172 +                       192100, 15, 15, 4, 23, 40, 41, 41 }, 
    173                 { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS_HGI, 300000, /* 300 Mb */ 
    174 -                       207000, 0x8f, 0x00, 15, 
    175 -                       4,  23, 40, 41, 41, 148400 }, 
    176 +                       207000, 15, 15, 4, 23, 40, 41, 41 }, 
    177         }, 
    178         50,  /* probe interval */ 
    179         WLAN_RC_HT_FLAG,  /* Phy rates allowed initially */ 
    180 @@ -156,177 +115,125 @@ static const struct ath_rate_table ar541 
     10                        5400, 0x0b, 0x00, 12, 
     11@@ -156,6 +157,7 @@ static const struct ath_rate_table ar541 
    18112  
    18213 static const struct ath_rate_table ar5416_11ng_ratetable = { 
     
    18516        { 
    18617                { VALID_ALL, VALID_ALL, WLAN_RC_PHY_CCK, 1000, /* 1 Mb */ 
    187 -                       900, 0x1b, 0x00, 2, 
    188 -                       0, 0, 0, 0, 0, 0 }, 
    189 +                       900, 0, 2, 0, 0, 0, 0, 0 }, 
    190                 { VALID_ALL, VALID_ALL, WLAN_RC_PHY_CCK, 2000, /* 2 Mb */ 
    191 -                       1900, 0x1a, 0x04, 4, 
    192 -                       1, 1, 1, 1, 1, 0 }, 
    193 +                       1900, 1, 4, 1, 1, 1, 1, 1 }, 
    194                 { VALID_ALL, VALID_ALL, WLAN_RC_PHY_CCK, 5500, /* 5.5 Mb */ 
    195 -                       4900, 0x19, 0x04, 11, 
    196 -                       2, 2, 2, 2, 2, 0 }, 
    197 +                       4900, 2, 11, 2, 2, 2, 2, 2 }, 
    198                 { VALID_ALL, VALID_ALL, WLAN_RC_PHY_CCK, 11000, /* 11 Mb */ 
    199 -                       8100, 0x18, 0x04, 22, 
    200 -                       3, 3, 3, 3, 3, 0 }, 
    201 +                       8100, 3, 22, 3, 3, 3, 3, 3 }, 
    202                 { INVALID, INVALID, WLAN_RC_PHY_OFDM, 6000, /* 6 Mb */ 
    203 -                       5400, 0x0b, 0x00, 12, 
    204 -                       4, 4, 4, 4, 4, 0 }, 
    205 +                       5400, 4, 12, 4, 4, 4, 4, 4 }, 
    206                 { INVALID, INVALID, WLAN_RC_PHY_OFDM, 9000, /* 9 Mb */ 
    207 -                       7800, 0x0f, 0x00, 18, 
    208 -                       4, 5, 5, 5, 5, 0 }, 
    209 +                       7800, 5, 18, 4, 5, 5, 5, 5 }, 
    210                 { VALID, VALID, WLAN_RC_PHY_OFDM, 12000, /* 12 Mb */ 
    211 -                       10100, 0x0a, 0x00, 24, 
    212 -                       6, 6, 6, 6, 6, 0 }, 
    213 +                       10100, 6, 24, 6, 6, 6, 6, 6 }, 
    214                 { VALID, VALID, WLAN_RC_PHY_OFDM, 18000, /* 18 Mb */ 
    215 -                       14100,  0x0e, 0x00, 36, 
    216 -                       6, 7, 7, 7, 7, 0 }, 
    217 +                       14100, 7, 36, 6, 7, 7, 7, 7 }, 
    218                 { VALID, VALID, WLAN_RC_PHY_OFDM, 24000, /* 24 Mb */ 
    219 -                       17700, 0x09, 0x00, 48, 
    220 -                       8,  8, 8, 8, 8, 0 }, 
    221 +                       17700, 8, 48, 8, 8, 8, 8, 8 }, 
    222                 { VALID, VALID, WLAN_RC_PHY_OFDM, 36000, /* 36 Mb */ 
    223 -                       23700, 0x0d, 0x00, 72, 
    224 -                       8,  9, 9, 9, 9, 0 }, 
    225 +                       23700, 9, 72, 8, 9, 9, 9, 9 }, 
    226                 { VALID, VALID, WLAN_RC_PHY_OFDM, 48000, /* 48 Mb */ 
    227 -                       27400, 0x08, 0x00, 96, 
    228 -                       8,  10, 10, 10, 10, 0 }, 
    229 +                       27400, 10, 96, 8, 10, 10, 10, 10 }, 
    230                 { VALID, VALID, WLAN_RC_PHY_OFDM, 54000, /* 54 Mb */ 
    231 -                       30900, 0x0c, 0x00, 108, 
    232 -                       8,  11, 11, 11, 11, 0 }, 
    233 +                       30900, 11, 108, 8, 11, 11, 11, 11 }, 
    234                 { INVALID, INVALID, WLAN_RC_PHY_HT_20_SS, 6500, /* 6.5 Mb */ 
    235 -                       6400, 0x80, 0x00, 0, 
    236 -                       4, 12, 28, 12, 28, 3216 }, 
    237 +                       6400, 0, 0, 4, 12, 28, 12, 28 }, 
    238                 { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 13000, /* 13 Mb */ 
    239 -                       12700, 0x81, 0x00, 1, 
    240 -                       6, 13, 29, 13, 29, 6434 }, 
    241 +                       12700, 1, 1, 6, 13, 29, 13, 29 }, 
    242                 { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 19500, /* 19.5 Mb */ 
    243 -                       18800, 0x82, 0x00, 2, 
    244 -                       6, 14, 30, 14, 30, 9650 }, 
    245 +                       18800, 2, 2, 6, 14, 30, 14, 30 }, 
    246                 { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 26000, /* 26 Mb */ 
    247 -                       25000, 0x83, 0x00, 3, 
    248 -                       8,  15, 31, 15, 31, 12868 }, 
    249 +                       25000, 3, 3, 8, 15, 31, 15, 31 }, 
    250                 { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 39000, /* 39 Mb */ 
    251 -                       36700, 0x84, 0x00, 4, 
    252 -                       8,  16, 32, 16, 32, 19304 }, 
    253 +                       36700, 4, 4, 8, 16, 32, 16, 32 }, 
    254                 { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 52000, /* 52 Mb */ 
    255 -                       48100, 0x85, 0x00, 5, 
    256 -                       8,  17, 33, 17, 33, 25740 }, 
    257 +                       48100, 5, 5, 8, 17, 33, 17, 33 }, 
    258                 { INVALID,  VALID_20, WLAN_RC_PHY_HT_20_SS, 58500, /* 58.5 Mb */ 
    259 -                       53500, 0x86, 0x00, 6, 
    260 -                       8,  18, 34, 18, 34, 28956 }, 
    261 +                       53500, 6, 6, 8, 18, 34, 18, 34 }, 
    262                 { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 65000, /* 65 Mb */ 
    263 -                       59000, 0x87, 0x00, 7, 
    264 -                       8,  19, 35, 19, 36, 32180 }, 
    265 +                       59000, 7, 7, 8, 19, 35, 19, 36 }, 
    266                 { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 13000, /* 13 Mb */ 
    267 -                       12700, 0x88, 0x00, 8, 
    268 -                       4, 20, 37, 20, 37, 6430 }, 
    269 +                       12700, 8, 8, 4, 20, 37, 20, 37 }, 
    270                 { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 26000, /* 26 Mb */ 
    271 -                       24800, 0x89, 0x00, 9, 
    272 -                       6, 21, 38, 21, 38, 12860 }, 
    273 +                       24800, 9, 9, 6, 21, 38, 21, 38 }, 
    274                 { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 39000, /* 39 Mb */ 
    275 -                       36600, 0x8a, 0x00, 10, 
    276 -                       6, 22, 39, 22, 39, 19300 }, 
    277 +                       36600, 10, 10, 6, 22, 39, 22, 39 }, 
    278                 { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 52000, /* 52 Mb */ 
    279 -                       48100, 0x8b, 0x00, 11, 
    280 -                       8,  23, 40, 23, 40, 25736 }, 
    281 +                       48100, 11, 11, 8, 23, 40, 23, 40 }, 
    282                 { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 78000, /* 78 Mb */ 
    283 -                       69500, 0x8c, 0x00, 12, 
    284 -                       8,  24, 41, 24, 41, 38600 }, 
    285 +                       69500, 12, 12, 8, 24, 41, 24, 41 }, 
    286                 { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 104000, /* 104 Mb */ 
    287 -                       89500, 0x8d, 0x00, 13, 
    288 -                       8,  25, 42, 25, 42, 51472 }, 
    289 +                       89500, 13, 13, 8, 25, 42, 25, 42 }, 
    290                 { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 117000, /* 117 Mb */ 
    291 -                       98900, 0x8e, 0x00, 14, 
    292 -                       8,  26, 43, 26, 44, 57890 }, 
    293 +                       98900, 14, 14, 8, 26, 43, 26, 44 }, 
    294                 { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 130000, /* 130 Mb */ 
    295 -                       108300, 0x8f, 0x00, 15, 
    296 -                       8,  27, 44, 27, 45, 64320 }, 
    297 +                       108300, 15, 15, 8, 27, 44, 27, 45 }, 
    298                 { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 13500, /* 13.5 Mb */ 
    299 -                       13200, 0x80, 0x00, 0, 
    300 -                       8, 12, 28, 28, 28, 6684 }, 
    301 +                       13200, 0, 0, 8, 12, 28, 28, 28 }, 
    302                 { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 27500, /* 27.0 Mb */ 
    303 -                       25900, 0x81, 0x00, 1, 
    304 -                       8, 13, 29, 29, 29, 13368 }, 
    305 +                       25900, 1, 1, 8, 13, 29, 29, 29 }, 
    306                 { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 40500, /* 40.5 Mb */ 
    307 -                       38600, 0x82, 0x00, 2, 
    308 -                       8, 14, 30, 30, 30, 20052 }, 
    309 +                       38600, 2, 2, 8, 14, 30, 30, 30 }, 
    310                 { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 54000, /* 54 Mb */ 
    311 -                       49800, 0x83, 0x00, 3, 
    312 -                       8,  15, 31, 31, 31, 26738 }, 
    313 +                       49800, 3, 3, 8,  15, 31, 31, 31 }, 
    314                 { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 81500, /* 81 Mb */ 
    315 -                       72200, 0x84, 0x00, 4, 
    316 -                       8,  16, 32, 32, 32, 40104 }, 
    317 +                       72200, 4, 4, 8, 16, 32, 32, 32 }, 
    318                 { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 108000, /* 108 Mb */ 
    319 -                       92900, 0x85, 0x00, 5, 
    320 -                       8,  17, 33, 33, 33, 53476 }, 
    321 +                       92900, 5, 5, 8, 17, 33, 33, 33 }, 
    322                 { INVALID,  VALID_40, WLAN_RC_PHY_HT_40_SS, 121500, /* 121.5 Mb */ 
    323 -                       102700, 0x86, 0x00, 6, 
    324 -                       8,  18, 34, 34, 34, 60156 }, 
    325 +                       102700, 6, 6, 8, 18, 34, 34, 34 }, 
    326                 { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 135000, /* 135 Mb */ 
    327 -                       112000, 0x87, 0x00, 7, 
    328 -                       8,  19, 35, 36, 36, 66840 }, 
    329 +                       112000, 7, 7, 8, 19, 35, 36, 36 }, 
    330                 { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS_HGI, 150000, /* 150 Mb */ 
    331 -                       122000, 0x87, 0x00, 7, 
    332 -                       8,  19, 35, 36, 36, 74200 }, 
    333 +                       122000, 7, 7, 8, 19, 35, 36, 36 }, 
    334                 { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 27000, /* 27 Mb */ 
    335 -                       25800, 0x88, 0x00, 8, 
    336 -                       8, 20, 37, 37, 37, 13360 }, 
    337 +                       25800, 8, 8, 8, 20, 37, 37, 37 }, 
    338                 { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 54000, /* 54 Mb */ 
    339 -                       49800, 0x89, 0x00, 9, 
    340 -                       8, 21, 38, 38, 38, 26720 }, 
    341 +                       49800, 9, 9, 8, 21, 38, 38, 38 }, 
    342                 { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 81000, /* 81 Mb */ 
    343 -                       71900, 0x8a, 0x00, 10, 
    344 -                       8, 22, 39, 39, 39, 40080 }, 
    345 +                       71900, 10, 10, 8, 22, 39, 39, 39 }, 
    346                 { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 108000, /* 108 Mb */ 
    347 -                       92500, 0x8b, 0x00, 11, 
    348 -                       8,  23, 40, 40, 40, 53440 }, 
    349 +                       92500, 11, 11, 8, 23, 40, 40, 40 }, 
    350                 { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 162000, /* 162 Mb */ 
    351 -                       130300, 0x8c, 0x00, 12, 
    352 -                       8,  24, 41, 41, 41, 80160 }, 
    353 +                       130300, 12, 12, 8, 24, 41, 41, 41 }, 
    354                 { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 216000, /* 216 Mb */ 
    355 -                       162800, 0x8d, 0x00, 13, 
    356 -                       8,  25, 42, 42, 42, 106880 }, 
    357 +                       162800, 13, 13, 8, 25, 42, 42, 42 }, 
    358                 { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 243000, /* 243 Mb */ 
    359 -                       178200, 0x8e, 0x00, 14, 
    360 -                       8,  26, 43, 43, 43, 120240 }, 
    361 +                       178200, 14, 14, 8, 26, 43, 43, 43 }, 
    362                 { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 270000, /* 270 Mb */ 
    363 -                       192100, 0x8f, 0x00, 15, 
    364 -                       8,  27, 44, 45, 45, 133600 }, 
    365 +                       192100, 15, 15, 8, 27, 44, 45, 45 }, 
    366                 { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS_HGI, 300000, /* 300 Mb */ 
    367 -                       207000, 0x8f, 0x00, 15, 
    368 -                       8,  27, 44, 45, 45, 148400 }, 
    369 -               }, 
    370 +                       207000, 15, 15, 8, 27, 44, 45, 45 }, 
    371 +       }, 
    372         50,  /* probe interval */ 
    373         WLAN_RC_HT_FLAG,  /* Phy rates allowed initially */ 
    374  }; 
     18                        900, 0x1b, 0x00, 2, 
     19@@ -302,6 +304,7 @@ static const struct ath_rate_table ar541 
    37520  
    37621 static const struct ath_rate_table ar5416_11a_ratetable = { 
     
    37924        { 
    38025                { VALID, VALID, WLAN_RC_PHY_OFDM, 6000, /* 6 Mb */ 
    381 -                       5400, 0x0b, 0x00, (0x80|12), 
    382 -                       0, 0, 0 }, 
    383 +                       5400, 0, 12, 0, 0, 0 }, 
    384                 { VALID, VALID, WLAN_RC_PHY_OFDM, 9000, /* 9 Mb */ 
    385 -                       7800, 0x0f, 0x00, 18, 
    386 -                       0, 1, 0 }, 
    387 +                       7800,  1, 18, 0, 1, 0 }, 
    388                 { VALID, VALID, WLAN_RC_PHY_OFDM, 12000, /* 12 Mb */ 
    389 -                       10000, 0x0a, 0x00, (0x80|24), 
    390 -                       2, 2, 0 }, 
    391 +                       10000, 2, 24, 2, 2, 0 }, 
    392                 { VALID, VALID, WLAN_RC_PHY_OFDM, 18000, /* 18 Mb */ 
    393 -                       13900, 0x0e, 0x00, 36, 
    394 -                       2, 3, 0 }, 
    395 +                       13900, 3, 36, 2, 3, 0 }, 
    396                 { VALID, VALID, WLAN_RC_PHY_OFDM, 24000, /* 24 Mb */ 
    397 -                       17300, 0x09, 0x00, (0x80|48), 
    398 -                       4,  4, 0 }, 
    399 +                       17300, 4, 48, 4, 4, 0 }, 
    400                 { VALID, VALID, WLAN_RC_PHY_OFDM, 36000, /* 36 Mb */ 
    401 -                       23000, 0x0d, 0x00, 72, 
    402 -                       4,  5, 0 }, 
    403 +                       23000, 5, 72, 4, 5, 0 }, 
    404                 { VALID, VALID, WLAN_RC_PHY_OFDM, 48000, /* 48 Mb */ 
    405 -                       27400, 0x08, 0x00, 96, 
    406 -                       4,  6, 0 }, 
    407 +                       27400, 6, 96, 4, 6, 0 }, 
    408                 { VALID, VALID, WLAN_RC_PHY_OFDM, 54000, /* 54 Mb */ 
    409 -                       29300, 0x0c, 0x00, 108, 
    410 -                       4,  7, 0 }, 
    411 +                       29300, 7, 108, 4, 7, 0 }, 
    412         }, 
    413         50,  /* probe interval */ 
    414         0,   /* Phy rates allowed initially */ 
    415 @@ -334,48 +241,51 @@ static const struct ath_rate_table ar541 
     26                        5400, 0x0b, 0x00, (0x80|12), 
     27@@ -334,6 +337,7 @@ static const struct ath_rate_table ar541 
    41628  
    41729 static const struct ath_rate_table ar5416_11g_ratetable = { 
     
    42032        { 
    42133                { VALID, VALID, WLAN_RC_PHY_CCK, 1000, /* 1 Mb */ 
    422 -                       900, 0x1b, 0x00, 2, 
    423 -                       0, 0, 0 }, 
    424 +                       900, 0, 2, 0, 0, 0 }, 
    425                 { VALID, VALID, WLAN_RC_PHY_CCK, 2000, /* 2 Mb */ 
    426 -                       1900, 0x1a, 0x04, 4, 
    427 -                       1, 1, 0 }, 
    428 +                       1900, 1, 4, 1, 1, 0 }, 
    429                 { VALID, VALID, WLAN_RC_PHY_CCK, 5500, /* 5.5 Mb */ 
    430 -                       4900, 0x19, 0x04, 11, 
    431 -                       2, 2, 0 }, 
    432 +                       4900, 2, 11, 2, 2, 0 }, 
    433                 { VALID, VALID, WLAN_RC_PHY_CCK, 11000, /* 11 Mb */ 
    434 -                       8100, 0x18, 0x04, 22, 
    435 -                       3, 3, 0 }, 
    436 +                       8100, 3, 22, 3, 3, 0 }, 
    437                 { INVALID, INVALID, WLAN_RC_PHY_OFDM, 6000, /* 6 Mb */ 
    438 -                       5400, 0x0b, 0x00, 12, 
    439 -                       4, 4, 0 }, 
    440 +                       5400, 4, 12, 4, 4, 0 }, 
    441                 { INVALID, INVALID, WLAN_RC_PHY_OFDM, 9000, /* 9 Mb */ 
    442 -                       7800, 0x0f, 0x00, 18, 
    443 -                       4, 5, 0 }, 
    444 +                       7800, 5, 18, 4, 5, 0 }, 
    445                 { VALID, VALID, WLAN_RC_PHY_OFDM, 12000, /* 12 Mb */ 
    446 -                       10000, 0x0a, 0x00, 24, 
    447 -                       6, 6, 0 }, 
    448 +                       10000, 6, 24, 6, 6, 0 }, 
    449                 { VALID, VALID, WLAN_RC_PHY_OFDM, 18000, /* 18 Mb */ 
    450 -                       13900, 0x0e, 0x00, 36, 
    451 -                       6, 7, 0 }, 
    452 +                       13900, 7, 36, 6, 7, 0 }, 
    453                 { VALID, VALID, WLAN_RC_PHY_OFDM, 24000, /* 24 Mb */ 
    454 -                       17300, 0x09, 0x00, 48, 
    455 -                       8,  8, 0 }, 
    456 +                       17300, 8, 48, 8, 8, 0 }, 
    457                 { VALID, VALID, WLAN_RC_PHY_OFDM, 36000, /* 36 Mb */ 
    458 -                       23000, 0x0d, 0x00, 72, 
    459 -                       8,  9, 0 }, 
    460 +                       23000, 9, 72, 8, 9, 0 }, 
    461                 { VALID, VALID, WLAN_RC_PHY_OFDM, 48000, /* 48 Mb */ 
    462 -                       27400, 0x08, 0x00, 96, 
    463 -                       8,  10, 0 }, 
    464 +                       27400, 10, 96, 8, 10, 0 }, 
    465                 { VALID, VALID, WLAN_RC_PHY_OFDM, 54000, /* 54 Mb */ 
    466 -                       29300, 0x0c, 0x00, 108, 
    467 -                       8,  11, 0 }, 
    468 +                       29300, 11, 108, 8, 11, 0 }, 
    469         }, 
    470         50,  /* probe interval */ 
     34                        900, 0x1b, 0x00, 2, 
     35@@ -376,6 +380,20 @@ static const struct ath_rate_table ar541 
    47136        0,   /* Phy rates allowed initially */ 
    47237 }; 
     
    48954 { 
    49055        if (a >= b) { 
    491 @@ -534,7 +444,7 @@ static u8 ath_rc_setvalid_rates(struct a 
     56@@ -534,7 +552,7 @@ static u8 ath_rc_setvalid_rates(struct a 
    49257                         * capflag matches one of the validity 
    49358                         * (VALID/VALID_20/VALID_40) flags */ 
     
    49863                             WLAN_RC_CAP_MODE(capflag)) && 
    49964                            !WLAN_RC_PHY_HT(phy)) { 
    500 @@ -576,8 +486,7 @@ static u8 ath_rc_setvalid_htrates(struct 
     65@@ -576,8 +594,7 @@ static u8 ath_rc_setvalid_htrates(struct 
    50166                        u8 rate = rateset->rs_rates[i]; 
    50267                        u8 dot11rate = rate_table->info[j].dot11rate; 
     
    50873                                continue; 
    50974  
    510 @@ -696,18 +605,20 @@ static void ath_rc_rate_set_series(const 
     75@@ -696,18 +713,20 @@ static void ath_rc_rate_set_series(const 
    51176                                   u8 tries, u8 rix, int rtsctsenable) 
    51277 { 
     
    535100  
    536101 static void ath_rc_rate_set_rtscts(struct ath_softc *sc, 
    537 @@ -720,7 +631,7 @@ static void ath_rc_rate_set_rtscts(struc 
     102@@ -720,7 +739,7 @@ static void ath_rc_rate_set_rtscts(struc 
    538103        /* get the cix for the lowest valid rix */ 
    539104        for (i = 3; i >= 0; i--) { 
     
    544109                } 
    545110        } 
    546 @@ -1080,15 +991,19 @@ static int ath_rc_get_rateindex(const st 
     111@@ -1080,15 +1099,19 @@ static int ath_rc_get_rateindex(const st 
    547112 { 
    548113        int rix; 
     
    568133        return rix; 
    569134 } 
    570 @@ -1183,7 +1098,9 @@ struct ath_rate_table *ath_choose_rate_t 
     135@@ -1183,7 +1206,9 @@ struct ath_rate_table *ath_choose_rate_t 
    571136  
    572137        ath_print(common, ATH_DBG_CONFIG, 
     
    579144  
    580145 static void ath_rc_init(struct ath_softc *sc, 
    581 @@ -1197,12 +1114,6 @@ static void ath_rc_init(struct ath_softc 
     146@@ -1197,12 +1222,6 @@ static void ath_rc_init(struct ath_softc 
    582147        u8 *ht_mcs = (u8 *)&ath_rc_priv->neg_ht_rates; 
    583148        u8 i, j, k, hi = 0, hthi = 0; 
     
    592157         * on the working rate set */ 
    593158        ath_rc_priv->rate_table_size = RATE_TABLE_SIZE; 
    594 @@ -1357,7 +1268,8 @@ static void ath_tx_status(void *priv, st 
     159@@ -1357,7 +1376,8 @@ static void ath_tx_status(void *priv, st 
    595160                } 
    596161        } 
     
    602167  
    603168 static void ath_rate_init(void *priv, struct ieee80211_supported_band *sband, 
    604 @@ -1365,7 +1277,7 @@ static void ath_rate_init(void *priv, st 
     169@@ -1365,7 +1385,7 @@ static void ath_rate_init(void *priv, st 
    605170 { 
    606171        struct ath_softc *sc = priv; 
     
    611176        int i, j = 0; 
    612177  
    613 @@ -1397,11 +1309,9 @@ static void ath_rate_init(void *priv, st 
     178@@ -1397,11 +1417,9 @@ static void ath_rate_init(void *priv, st 
    614179            (sc->sc_ah->opmode == NL80211_IFTYPE_MESH_POINT) || 
    615180            (sc->sc_ah->opmode == NL80211_IFTYPE_ADHOC)) { 
     
    626191  
    627192        ath_rc_priv->ht_cap = ath_rc_build_ht_caps(sc, sta, is_cw40, is_sgi40); 
    628 @@ -1445,6 +1355,7 @@ static void ath_rate_update(void *priv,  
     193@@ -1445,6 +1463,7 @@ static void ath_rate_update(void *priv,  
    629194                        ath_print(ath9k_hw_common(sc->sc_ah), ATH_DBG_CONFIG, 
    630195                                  "Operating HT Bandwidth changed to: %d\n", 
     
    634199        } 
    635200 } 
    636 @@ -1497,26 +1408,6 @@ static struct rate_control_ops ath_rate_ 
     201@@ -1497,26 +1516,6 @@ static struct rate_control_ops ath_rate_ 
    637202        .free_sta = ath_rate_free_sta, 
    638203 }; 
     
    880445  
    881446        /* set dur_update_en for l-sig computation except for PS-Poll frames */ 
     447@@ -1925,8 +1967,10 @@ static void ath_tx_rc_status(struct ath_ 
     448                } 
     449        } 
     450  
     451-       for (i = tx_rateindex + 1; i < hw->max_rates; i++) 
     452+       for (i = tx_rateindex + 1; i < hw->max_rates; i++) { 
     453                tx_info->status.rates[i].count = 0; 
     454+               tx_info->status.rates[i].idx = -1; 
     455+       } 
     456  
     457        tx_info->status.rates[tx_rateindex].count = bf->bf_retries + 1; 
     458 } 
    882459--- a/drivers/net/wireless/ath/ath9k/ath9k.h 
    883460+++ b/drivers/net/wireless/ath/ath9k/ath9k.h 
     
    911488--- a/drivers/net/wireless/ath/ath9k/main.c 
    912489+++ b/drivers/net/wireless/ath/ath9k/main.c 
    913 @@ -105,37 +105,71 @@ static struct ieee80211_channel ath9k_5g 
     490@@ -105,37 +105,55 @@ static struct ieee80211_channel ath9k_5g 
    914491        CHAN5G(5825, 37), /* Channel 165 */ 
    915492 }; 
    916493  
     494+/* Atheros hardware rate code addition for short premble */ 
     495+#define SHPCHECK(__hw_rate, __flags) \ 
     496+       ((__flags & IEEE80211_RATE_SHORT_PREAMBLE) ? (__hw_rate | 0x04 ) : 0) 
     497+ 
     498+#define RATE(_bitrate, _hw_rate, _flags) {              \ 
     499+       .bitrate        = (_bitrate),                   \ 
     500+       .flags          = (_flags),                     \ 
     501+       .hw_value       = (_hw_rate),                   \ 
     502+       .hw_value_short = (SHPCHECK(_hw_rate, _flags))  \ 
     503+} 
     504+ 
    917505+static struct ieee80211_rate ath9k_legacy_rates[] = { 
    918 +       { .bitrate = 10, 
    919 +         .hw_value = 0x1b, 
    920 +         .flags = 0 }, 
    921 +       { .bitrate = 20, 
    922 +         .hw_value = 0x1a, 
    923 +         .hw_value_short = 0x1a | 0x04, 
    924 +         .flags = IEEE80211_RATE_SHORT_PREAMBLE }, 
    925 +       { .bitrate = 55, 
    926 +         .hw_value = 0x19, 
    927 +         .hw_value_short = 0x19 | 0x04, 
    928 +         .flags = IEEE80211_RATE_SHORT_PREAMBLE }, 
    929 +       { .bitrate = 110, 
    930 +         .hw_value = 0x18, 
    931 +         .hw_value_short = 0x18 | 0x4, 
    932 +         .flags = IEEE80211_RATE_SHORT_PREAMBLE }, 
    933 +       { .bitrate = 60, 
    934 +         .hw_value = 0x0b, 
    935 +         .flags = 0 }, 
    936 +       { .bitrate = 90, 
    937 +         .hw_value = 0x0f, 
    938 +         .flags = 0 }, 
    939 +       { .bitrate = 120, 
    940 +         .hw_value = 0x0a, 
    941 +         .flags = 0 }, 
    942 +       { .bitrate = 180, 
    943 +         .hw_value = 0x0e, 
    944 +         .flags = 0 }, 
    945 +       { .bitrate = 240, 
    946 +         .hw_value = 0x09, 
    947 +         .flags = 0 }, 
    948 +       { .bitrate = 360, 
    949 +         .hw_value = 0x0d, 
    950 +         .flags = 0 }, 
    951 +       { .bitrate = 480, 
    952 +         .hw_value = 0x08, 
    953 +         .flags = 0 }, 
    954 +       { .bitrate = 540, 
    955 +         .hw_value = 0x0c, 
    956 +         .flags = 0 }, 
     506+       RATE(10, 0x1b, 0), 
     507+       RATE(20, 0x1a, IEEE80211_RATE_SHORT_PREAMBLE), 
     508+       RATE(55, 0x19, IEEE80211_RATE_SHORT_PREAMBLE), 
     509+       RATE(110, 0x18, IEEE80211_RATE_SHORT_PREAMBLE), 
     510+       RATE(60, 0x0b, 0), 
     511+       RATE(90, 0x0f, 0), 
     512+       RATE(120, 0x0a, 0), 
     513+       RATE(180, 0x0e, 0), 
     514+       RATE(240, 0x09, 0), 
     515+       RATE(360, 0x0d, 0), 
     516+       RATE(480, 0x08, 0), 
     517+       RATE(540, 0x0c, 0), 
    957518+}; 
    958519+ 
     
    999560        default: 
    1000561                BUG_ON(1); 
    1001 @@ -191,51 +225,6 @@ static u8 parse_mpdudensity(u8 mpdudensi 
     562@@ -191,51 +209,6 @@ static u8 parse_mpdudensity(u8 mpdudensi 
    1002563        } 
    1003564 } 
     
    1051612                                                struct ieee80211_hw *hw) 
    1052613 { 
    1053 @@ -1713,12 +1702,6 @@ static int ath_init_softc(u16 devid, str 
     614@@ -1713,12 +1686,6 @@ static int ath_init_softc(u16 devid, str 
    1054615        /* default to MONITOR mode */ 
    1055616        sc->sc_ah->opmode = NL80211_IFTYPE_MONITOR; 
     
    1064625         * Allocate hardware transmit queues: one queue for 
    1065626         * beacon frames and one data queue for each QoS 
    1066 @@ -1839,19 +1822,22 @@ static int ath_init_softc(u16 devid, str 
     627@@ -1839,19 +1806,22 @@ static int ath_init_softc(u16 devid, str 
    1067628        /* setup channels and rates */ 
    1068629  
     
    1101662                int valid; 
    1102663                int valid_single_stream; 
    1103 @@ -111,14 +112,12 @@ struct ath_rate_table { 
    1104                 u32 ratekbps; 
    1105                 u32 user_ratekbps; 
    1106                 u8 ratecode; 
    1107 -               u8 short_preamble; 
    1108                 u8 dot11rate; 
    1109                 u8 ctrl_rate; 
    1110                 u8 base_index; 
    1111                 u8 cw40index; 
    1112                 u8 sgi_index; 
    1113                 u8 ht_index; 
    1114 -               u32 max_4ms_framelen; 
    1115         } info[RATE_TABLE_SIZE]; 
    1116         u32 probe_interval; 
    1117         u8 initial_ratemax; 
    1118 @@ -179,8 +178,6 @@ enum ath9k_internal_frame_type { 
     664@@ -179,8 +180,6 @@ enum ath9k_internal_frame_type { 
    1119665        ATH9K_INT_UNPAUSE 
    1120666 }; 
     
    1145691-       rt = sc->cur_rate_table; 
    1146692-       rate = rt->info[0].ratecode; 
    1147 +       sband = &sc->sbands[sc->hw->conf.channel->band]; 
     693+       sband = &sc->sbands[common->hw->conf.channel->band]; 
    1148694+       rate = sband->bitrates[0].hw_value; 
    1149695        if (sc->sc_flags & SC_OP_PREAMBLE_SHORT) 
Note: See TracChangeset for help on using the changeset viewer.