1 /* 2 * Copyright (c) 2010-2011 Atheros Communications Inc. 3 * Copyright (c) 2011-2012 Qualcomm Atheros Inc. 4 * 5 * Permission to use, copy, modify, and/or distribute this software for any 6 * purpose with or without fee is hereby granted, provided that the above 7 * copyright notice and this permission notice appear in all copies. 8 * 9 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES 10 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF 11 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR 12 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES 13 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN 14 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF 15 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 16 */ 17 18 #ifndef INITVALS_953X_H 19 #define INITVALS_953X_H 20 21 #define qca953x_1p0_mac_postamble ar9300_2p2_mac_postamble 22 23 #define qca953x_1p0_soc_preamble ar955x_1p0_soc_preamble 24 25 #define qca953x_1p0_soc_postamble ar9300_2p2_soc_postamble 26 27 #define qca953x_1p0_common_rx_gain_table ar9300Common_rx_gain_table_2p2 28 29 #define qca953x_1p0_common_wo_xlna_rx_gain_table ar9300Common_wo_xlna_rx_gain_table_2p2 30 31 #define qca953x_1p0_modes_fast_clock ar9300Modes_fast_clock_2p2 32 33 #define qca953x_1p0_common_wo_xlna_rx_gain_bounds ar955x_1p0_common_wo_xlna_rx_gain_bounds 34 35 #define qca953x_1p0_common_rx_gain_bounds ar955x_1p0_common_rx_gain_bounds 36 37 static const u32 qca953x_1p0_mac_core[][2] = { 38 /* Addr allmodes */ 39 {0x00000008, 0x00000000}, 40 {0x00000030, 0x00020085}, 41 {0x00000034, 0x00000005}, 42 {0x00000040, 0x00000000}, 43 {0x00000044, 0x00000000}, 44 {0x00000048, 0x00000008}, 45 {0x0000004c, 0x00000010}, 46 {0x00000050, 0x00000000}, 47 {0x00001040, 0x002ffc0f}, 48 {0x00001044, 0x002ffc0f}, 49 {0x00001048, 0x002ffc0f}, 50 {0x0000104c, 0x002ffc0f}, 51 {0x00001050, 0x002ffc0f}, 52 {0x00001054, 0x002ffc0f}, 53 {0x00001058, 0x002ffc0f}, 54 {0x0000105c, 0x002ffc0f}, 55 {0x00001060, 0x002ffc0f}, 56 {0x00001064, 0x002ffc0f}, 57 {0x000010f0, 0x00000100}, 58 {0x00001270, 0x00000000}, 59 {0x000012b0, 0x00000000}, 60 {0x000012f0, 0x00000000}, 61 {0x0000143c, 0x00000000}, 62 {0x0000147c, 0x00000000}, 63 {0x00008000, 0x00000000}, 64 {0x00008004, 0x00000000}, 65 {0x00008008, 0x00000000}, 66 {0x0000800c, 0x00000000}, 67 {0x00008018, 0x00000000}, 68 {0x00008020, 0x00000000}, 69 {0x00008038, 0x00000000}, 70 {0x0000803c, 0x00000000}, 71 {0x00008040, 0x00000000}, 72 {0x00008044, 0x00000000}, 73 {0x00008048, 0x00000000}, 74 {0x0000804c, 0xffffffff}, 75 {0x00008054, 0x00000000}, 76 {0x00008058, 0x00000000}, 77 {0x0000805c, 0x000fc78f}, 78 {0x00008060, 0x0000000f}, 79 {0x00008064, 0x00000000}, 80 {0x00008070, 0x00000310}, 81 {0x00008074, 0x00000020}, 82 {0x00008078, 0x00000000}, 83 {0x0000809c, 0x0000000f}, 84 {0x000080a0, 0x00000000}, 85 {0x000080a4, 0x02ff0000}, 86 {0x000080a8, 0x0e070605}, 87 {0x000080ac, 0x0000000d}, 88 {0x000080b0, 0x00000000}, 89 {0x000080b4, 0x00000000}, 90 {0x000080b8, 0x00000000}, 91 {0x000080bc, 0x00000000}, 92 {0x000080c0, 0x2a800000}, 93 {0x000080c4, 0x06900168}, 94 {0x000080c8, 0x13881c22}, 95 {0x000080cc, 0x01f40000}, 96 {0x000080d0, 0x00252500}, 97 {0x000080d4, 0x00a00000}, 98 {0x000080d8, 0x00400000}, 99 {0x000080dc, 0x00000000}, 100 {0x000080e0, 0xffffffff}, 101 {0x000080e4, 0x0000ffff}, 102 {0x000080e8, 0x3f3f3f3f}, 103 {0x000080ec, 0x00000000}, 104 {0x000080f0, 0x00000000}, 105 {0x000080f4, 0x00000000}, 106 {0x000080fc, 0x00020000}, 107 {0x00008100, 0x00000000}, 108 {0x00008108, 0x00000052}, 109 {0x0000810c, 0x00000000}, 110 {0x00008110, 0x00000000}, 111 {0x00008114, 0x000007ff}, 112 {0x00008118, 0x000000aa}, 113 {0x0000811c, 0x00003210}, 114 {0x00008124, 0x00000000}, 115 {0x00008128, 0x00000000}, 116 {0x0000812c, 0x00000000}, 117 {0x00008130, 0x00000000}, 118 {0x00008134, 0x00000000}, 119 {0x00008138, 0x00000000}, 120 {0x0000813c, 0x0000ffff}, 121 {0x00008140, 0x000000fe}, 122 {0x00008144, 0xffffffff}, 123 {0x00008168, 0x00000000}, 124 {0x0000816c, 0x00000000}, 125 {0x000081c0, 0x00000000}, 126 {0x000081c4, 0x33332210}, 127 {0x000081ec, 0x00000000}, 128 {0x000081f0, 0x00000000}, 129 {0x000081f4, 0x00000000}, 130 {0x000081f8, 0x00000000}, 131 {0x000081fc, 0x00000000}, 132 {0x00008240, 0x00100000}, 133 {0x00008244, 0x0010f3d7}, 134 {0x00008248, 0x00000852}, 135 {0x0000824c, 0x0001e7ae}, 136 {0x00008250, 0x00000000}, 137 {0x00008254, 0x00000000}, 138 {0x00008258, 0x00000000}, 139 {0x0000825c, 0x40000000}, 140 {0x00008260, 0x00080922}, 141 {0x00008264, 0x9d400010}, 142 {0x00008268, 0xffffffff}, 143 {0x0000826c, 0x0000ffff}, 144 {0x00008270, 0x00000000}, 145 {0x00008274, 0x40000000}, 146 {0x00008278, 0x003e4180}, 147 {0x0000827c, 0x00000004}, 148 {0x00008284, 0x0000002c}, 149 {0x00008288, 0x0000002c}, 150 {0x0000828c, 0x000000ff}, 151 {0x00008294, 0x00000000}, 152 {0x00008298, 0x00000000}, 153 {0x0000829c, 0x00000000}, 154 {0x00008300, 0x00001d40}, 155 {0x00008314, 0x00000000}, 156 {0x0000831c, 0x0000010d}, 157 {0x00008328, 0x00000000}, 158 {0x0000832c, 0x0000001f}, 159 {0x00008330, 0x00000302}, 160 {0x00008334, 0x00000700}, 161 {0x00008338, 0xffff0000}, 162 {0x0000833c, 0x02400000}, 163 {0x00008340, 0x000107ff}, 164 {0x00008344, 0xaa48107b}, 165 {0x00008348, 0x008f0000}, 166 {0x0000835c, 0x00000000}, 167 {0x00008360, 0xffffffff}, 168 {0x00008364, 0xffffffff}, 169 {0x00008368, 0x00000000}, 170 {0x00008370, 0x00000000}, 171 {0x00008374, 0x000000ff}, 172 {0x00008378, 0x00000000}, 173 {0x0000837c, 0x00000000}, 174 {0x00008380, 0xffffffff}, 175 {0x00008384, 0xffffffff}, 176 {0x00008390, 0xffffffff}, 177 {0x00008394, 0xffffffff}, 178 {0x00008398, 0x00000000}, 179 {0x0000839c, 0x00000000}, 180 {0x000083a0, 0x00000000}, 181 {0x000083a4, 0x0000fa14}, 182 {0x000083a8, 0x000f0c00}, 183 {0x000083ac, 0x33332210}, 184 {0x000083b0, 0x33332210}, 185 {0x000083b4, 0x33332210}, 186 {0x000083b8, 0x33332210}, 187 {0x000083bc, 0x00000000}, 188 {0x000083c0, 0x00000000}, 189 {0x000083c4, 0x00000000}, 190 {0x000083c8, 0x00000000}, 191 {0x000083cc, 0x00000200}, 192 {0x000083d0, 0x8c7901ff}, 193 }; 194 195 static const u32 qca953x_1p0_baseband_core[][2] = { 196 /* Addr allmodes */ 197 {0x00009800, 0xafe68e30}, 198 {0x00009804, 0xfd14e000}, 199 {0x00009808, 0x9c0a9f6b}, 200 {0x0000980c, 0x04900000}, 201 {0x00009814, 0x0280c00a}, 202 {0x00009818, 0x00000000}, 203 {0x0000981c, 0x00020028}, 204 {0x00009834, 0x6400a190}, 205 {0x00009838, 0x0108ecff}, 206 {0x0000983c, 0x14000600}, 207 {0x00009880, 0x201fff00}, 208 {0x00009884, 0x00001042}, 209 {0x000098a4, 0x00200400}, 210 {0x000098b0, 0x32840bbe}, 211 {0x000098bc, 0x00000002}, 212 {0x000098d0, 0x004b6a8e}, 213 {0x000098d4, 0x00000820}, 214 {0x000098dc, 0x00000000}, 215 {0x000098f0, 0x00000000}, 216 {0x000098f4, 0x00000000}, 217 {0x00009c04, 0xff55ff55}, 218 {0x00009c08, 0x0320ff55}, 219 {0x00009c0c, 0x00000000}, 220 {0x00009c10, 0x00000000}, 221 {0x00009c14, 0x00046384}, 222 {0x00009c18, 0x05b6b440}, 223 {0x00009c1c, 0x00b6b440}, 224 {0x00009d00, 0xc080a333}, 225 {0x00009d04, 0x40206c10}, 226 {0x00009d08, 0x009c4060}, 227 {0x00009d0c, 0x9883800a}, 228 {0x00009d10, 0x018848c6}, 229 {0x00009d14, 0x00c0040b}, 230 {0x00009d18, 0x00000000}, 231 {0x00009e08, 0x0038230c}, 232 {0x00009e24, 0x990bb515}, 233 {0x00009e28, 0x0c6f0000}, 234 {0x00009e30, 0x06336f77}, 235 {0x00009e34, 0x6af6532f}, 236 {0x00009e38, 0x0cc80c00}, 237 {0x00009e40, 0x0d261820}, 238 {0x00009e4c, 0x00001004}, 239 {0x00009e50, 0x00ff03f1}, 240 {0x00009fc0, 0x813e4788}, 241 {0x00009fc4, 0x0001efb5}, 242 {0x00009fcc, 0x40000014}, 243 {0x00009fd0, 0x01193b91}, 244 {0x0000a20c, 0x00000000}, 245 {0x0000a220, 0x00000000}, 246 {0x0000a224, 0x00000000}, 247 {0x0000a228, 0x10002310}, 248 {0x0000a23c, 0x00000000}, 249 {0x0000a244, 0x0c000000}, 250 {0x0000a248, 0x00000140}, 251 {0x0000a2a0, 0x00000007}, 252 {0x0000a2c0, 0x00000007}, 253 {0x0000a2c8, 0x00000000}, 254 {0x0000a2d4, 0x00000000}, 255 {0x0000a2ec, 0x00000000}, 256 {0x0000a2f0, 0x00000000}, 257 {0x0000a2f4, 0x00000000}, 258 {0x0000a2f8, 0x00000000}, 259 {0x0000a344, 0x00000000}, 260 {0x0000a34c, 0x00000000}, 261 {0x0000a350, 0x0000a000}, 262 {0x0000a364, 0x00000000}, 263 {0x0000a370, 0x00000000}, 264 {0x0000a390, 0x00000001}, 265 {0x0000a394, 0x00000444}, 266 {0x0000a398, 0x001f0e0f}, 267 {0x0000a39c, 0x0075393f}, 268 {0x0000a3a0, 0xb79f6427}, 269 {0x0000a3a4, 0x000000ff}, 270 {0x0000a3a8, 0x6a6a6a6a}, 271 {0x0000a3ac, 0x6a6a6a6a}, 272 {0x0000a3b0, 0x00c8641a}, 273 {0x0000a3b4, 0x0000001a}, 274 {0x0000a3b8, 0x0088642a}, 275 {0x0000a3bc, 0x000001fa}, 276 {0x0000a3c0, 0x20202020}, 277 {0x0000a3c4, 0x22222220}, 278 {0x0000a3c8, 0x20200020}, 279 {0x0000a3cc, 0x20202020}, 280 {0x0000a3d0, 0x20202020}, 281 {0x0000a3d4, 0x20202020}, 282 {0x0000a3d8, 0x20202020}, 283 {0x0000a3dc, 0x20202020}, 284 {0x0000a3e0, 0x20202020}, 285 {0x0000a3e4, 0x20202020}, 286 {0x0000a3e8, 0x20202020}, 287 {0x0000a3ec, 0x20202020}, 288 {0x0000a3f0, 0x00000000}, 289 {0x0000a3f4, 0x00000000}, 290 {0x0000a3f8, 0x0c9bd380}, 291 {0x0000a3fc, 0x000f0f01}, 292 {0x0000a400, 0x8fa91f01}, 293 {0x0000a404, 0x00000000}, 294 {0x0000a408, 0x0e79e5c6}, 295 {0x0000a40c, 0x00820820}, 296 {0x0000a414, 0x1ce42108}, 297 {0x0000a418, 0x2d001dce}, 298 {0x0000a41c, 0x1ce73908}, 299 {0x0000a420, 0x000001ce}, 300 {0x0000a424, 0x1ce738e7}, 301 {0x0000a428, 0x000001ce}, 302 {0x0000a42c, 0x1ce739ce}, 303 {0x0000a430, 0x1ce739ce}, 304 {0x0000a434, 0x00000000}, 305 {0x0000a438, 0x00001801}, 306 {0x0000a43c, 0x00100000}, 307 {0x0000a444, 0x00000000}, 308 {0x0000a448, 0x05000080}, 309 {0x0000a44c, 0x00000001}, 310 {0x0000a450, 0x00010000}, 311 {0x0000a458, 0x00000000}, 312 {0x0000a644, 0xbfad9d74}, 313 {0x0000a648, 0x0048060a}, 314 {0x0000a64c, 0x00003c37}, 315 {0x0000a670, 0x03020100}, 316 {0x0000a674, 0x09080504}, 317 {0x0000a678, 0x0d0c0b0a}, 318 {0x0000a67c, 0x13121110}, 319 {0x0000a680, 0x31301514}, 320 {0x0000a684, 0x35343332}, 321 {0x0000a688, 0x00000036}, 322 {0x0000a690, 0x08000838}, 323 {0x0000a7cc, 0x00000000}, 324 {0x0000a7d0, 0x00000000}, 325 {0x0000a7d4, 0x00000004}, 326 {0x0000a7dc, 0x00000000}, 327 {0x0000a8d0, 0x004b6a8e}, 328 {0x0000a8d4, 0x00000820}, 329 {0x0000a8dc, 0x00000000}, 330 {0x0000a8f0, 0x00000000}, 331 {0x0000a8f4, 0x00000000}, 332 {0x0000b2d0, 0x00000080}, 333 {0x0000b2d4, 0x00000000}, 334 {0x0000b2ec, 0x00000000}, 335 {0x0000b2f0, 0x00000000}, 336 {0x0000b2f4, 0x00000000}, 337 {0x0000b2f8, 0x00000000}, 338 {0x0000b408, 0x0e79e5c0}, 339 {0x0000b40c, 0x00820820}, 340 {0x0000b420, 0x00000000}, 341 }; 342 343 static const u32 qca953x_1p0_baseband_postamble[][5] = { 344 /* Addr 5G_HT20 5G_HT40 2G_HT40 2G_HT20 */ 345 {0x00009810, 0xd00a8005, 0xd00a8005, 0xd00a8011, 0xd00a8011}, 346 {0x00009820, 0x206a022e, 0x206a022e, 0x206a012e, 0x206a012e}, 347 {0x00009824, 0x5ac640d0, 0x5ac640d0, 0x5ac640d0, 0x5ac640d0}, 348 {0x00009828, 0x06903081, 0x06903081, 0x06903881, 0x06903881}, 349 {0x0000982c, 0x05eea6d4, 0x05eea6d4, 0x05eea6d4, 0x05eea6d4}, 350 {0x00009830, 0x0000059c, 0x0000059c, 0x0000119c, 0x0000119c}, 351 {0x00009c00, 0x000000c4, 0x000000c4, 0x000000c4, 0x000000c4}, 352 {0x00009e00, 0x0372111a, 0x0372111a, 0x037216a0, 0x037216a0}, 353 {0x00009e04, 0x001c2020, 0x001c2020, 0x001c2020, 0x001c2020}, 354 {0x00009e0c, 0x6c4000e2, 0x6d4000e2, 0x6d4000e2, 0x6c4000e2}, 355 {0x00009e10, 0x7ec88d2e, 0x7ec88d2e, 0x7ec84d2e, 0x7ec84d2e}, 356 {0x00009e14, 0x37b95d5e, 0x37b9605e, 0x3379605e, 0x33795d5e}, 357 {0x00009e18, 0x00000000, 0x00000000, 0x00000000, 0x00000000}, 358 {0x00009e1c, 0x0001cf9c, 0x0001cf9c, 0x00021f9c, 0x00021f9c}, 359 {0x00009e20, 0x000003b5, 0x000003b5, 0x000003ce, 0x000003ce}, 360 {0x00009e2c, 0x0000001c, 0x0000001c, 0x00000021, 0x00000021}, 361 {0x00009e3c, 0xcfa10820, 0xcfa10820, 0xcfa10820, 0xcfa10820}, 362 {0x00009e44, 0xfe321e27, 0xfe321e27, 0xfe291e27, 0xfe291e27}, 363 {0x00009e48, 0x5030201a, 0x5030201a, 0x50302012, 0x50302012}, 364 {0x00009fc8, 0x0003f000, 0x0003f000, 0x0001a000, 0x0001a000}, 365 {0x0000a204, 0x005c0ec0, 0x005c0ec4, 0x005c0ec4, 0x005c0ec0}, 366 {0x0000a208, 0x00000104, 0x00000104, 0x00000004, 0x00000004}, 367 {0x0000a22c, 0x07e26a2f, 0x07e26a2f, 0x01026a2f, 0x01026a2f}, 368 {0x0000a230, 0x0000000a, 0x00000014, 0x00000016, 0x0000000b}, 369 {0x0000a234, 0x00000fff, 0x10000fff, 0x10000fff, 0x00000fff}, 370 {0x0000a238, 0xffb01018, 0xffb01018, 0xffb01018, 0xffb01018}, 371 {0x0000a250, 0x00000000, 0x00000000, 0x00000210, 0x00000108}, 372 {0x0000a254, 0x000007d0, 0x00000fa0, 0x00001130, 0x00000898}, 373 {0x0000a258, 0x02020002, 0x02020002, 0x02020002, 0x02020002}, 374 {0x0000a25c, 0x01000e0e, 0x01000e0e, 0x01010e0e, 0x01010e0e}, 375 {0x0000a260, 0x0a021501, 0x0a021501, 0x3a021501, 0x3a021501}, 376 {0x0000a264, 0x00000e0e, 0x00000e0e, 0x01000e0e, 0x01000e0e}, 377 {0x0000a280, 0x00000007, 0x00000007, 0x0000000b, 0x0000000b}, 378 {0x0000a284, 0x00000000, 0x00000000, 0x00000010, 0x00000010}, 379 {0x0000a288, 0x00000110, 0x00000110, 0x00000110, 0x00000110}, 380 {0x0000a28c, 0x00022222, 0x00022222, 0x00022222, 0x00022222}, 381 {0x0000a2c4, 0x00158d18, 0x00158d18, 0x00058d18, 0x00058d18}, 382 {0x0000a2cc, 0x18c50033, 0x18c43433, 0x18c41033, 0x18c44c33}, 383 {0x0000a2d0, 0x00041982, 0x00041982, 0x00041982, 0x00041982}, 384 {0x0000a2d8, 0x7999a83b, 0x7999a83b, 0x7999a83b, 0x7999a83b}, 385 {0x0000a358, 0x00000000, 0x00000000, 0x00000000, 0x00000000}, 386 {0x0000a830, 0x0000019c, 0x0000019c, 0x0000019c, 0x0000019c}, 387 {0x0000ae04, 0x001c0000, 0x001c0000, 0x001c0000, 0x001c0000}, 388 {0x0000ae18, 0x00000000, 0x00000000, 0x00000000, 0x00000000}, 389 {0x0000ae1c, 0x0000019c, 0x0000019c, 0x0000019c, 0x0000019c}, 390 {0x0000ae20, 0x000001b5, 0x000001b5, 0x000001ce, 0x000001ce}, 391 {0x0000b284, 0x00000000, 0x00000000, 0x00000010, 0x00000010}, 392 }; 393 394 static const u32 qca953x_1p0_radio_core[][2] = { 395 /* Addr allmodes */ 396 {0x00016000, 0x36db6db6}, 397 {0x00016004, 0x6db6db40}, 398 {0x00016008, 0x73f00000}, 399 {0x0001600c, 0x00000000}, 400 {0x00016040, 0x3f80fff8}, 401 {0x0001604c, 0x000f0278}, 402 {0x00016050, 0x8036db6c}, 403 {0x00016054, 0x6db60000}, 404 {0x00016080, 0x00080000}, 405 {0x00016084, 0x0e48048c}, 406 {0x00016088, 0x14214514}, 407 {0x0001608c, 0x119f080a}, 408 {0x00016090, 0x24926490}, 409 {0x00016094, 0x00000000}, 410 {0x000160a0, 0xc2108ffe}, 411 {0x000160a4, 0x812fc370}, 412 {0x000160a8, 0x423c8000}, 413 {0x000160b4, 0x92480080}, 414 {0x000160c0, 0x006db6d8}, 415 {0x000160c4, 0x24b6db6c}, 416 {0x000160c8, 0x6db6db6c}, 417 {0x000160cc, 0x6db6fb7c}, 418 {0x000160d0, 0x6db6da44}, 419 {0x00016100, 0x07ff8001}, 420 {0x00016108, 0x00080010}, 421 {0x00016144, 0x01884080}, 422 {0x00016148, 0x000080d8}, 423 {0x00016280, 0x01000901}, 424 {0x00016284, 0x15d30000}, 425 {0x00016288, 0x00318000}, 426 {0x0001628c, 0x50000000}, 427 {0x00016380, 0x00000000}, 428 {0x00016384, 0x00000000}, 429 {0x00016388, 0x00800700}, 430 {0x0001638c, 0x00800700}, 431 {0x00016390, 0x00800700}, 432 {0x00016394, 0x00000000}, 433 {0x00016398, 0x00000000}, 434 {0x0001639c, 0x00000000}, 435 {0x000163a0, 0x00000001}, 436 {0x000163a4, 0x00000001}, 437 {0x000163a8, 0x00000000}, 438 {0x000163ac, 0x00000000}, 439 {0x000163b0, 0x00000000}, 440 {0x000163b4, 0x00000000}, 441 {0x000163b8, 0x00000000}, 442 {0x000163bc, 0x00000000}, 443 {0x000163c0, 0x000000a0}, 444 {0x000163c4, 0x000c0000}, 445 {0x000163c8, 0x14021402}, 446 {0x000163cc, 0x00001402}, 447 {0x000163d0, 0x00000000}, 448 {0x000163d4, 0x00000000}, 449 {0x00016400, 0x36db6db6}, 450 {0x00016404, 0x6db6db40}, 451 {0x00016408, 0x73f00000}, 452 {0x0001640c, 0x00000000}, 453 {0x00016440, 0x3f80fff8}, 454 {0x0001644c, 0x000f0278}, 455 {0x00016450, 0x8036db6c}, 456 {0x00016454, 0x6db60000}, 457 {0x00016500, 0x07ff8001}, 458 {0x00016508, 0x00080010}, 459 {0x00016544, 0x01884080}, 460 {0x00016548, 0x000080d8}, 461 {0x00016780, 0x00000000}, 462 {0x00016784, 0x00000000}, 463 {0x00016788, 0x00800700}, 464 {0x0001678c, 0x00800700}, 465 {0x00016790, 0x00800700}, 466 {0x00016794, 0x00000000}, 467 {0x00016798, 0x00000000}, 468 {0x0001679c, 0x00000000}, 469 {0x000167a0, 0x00000001}, 470 {0x000167a4, 0x00000001}, 471 {0x000167a8, 0x00000000}, 472 {0x000167ac, 0x00000000}, 473 {0x000167b0, 0x00000000}, 474 {0x000167b4, 0x00000000}, 475 {0x000167b8, 0x00000000}, 476 {0x000167bc, 0x00000000}, 477 {0x000167c0, 0x000000a0}, 478 {0x000167c4, 0x000c0000}, 479 {0x000167c8, 0x14021402}, 480 {0x000167cc, 0x00001402}, 481 {0x000167d0, 0x00000000}, 482 {0x000167d4, 0x00000000}, 483 }; 484 485 static const u32 qca953x_1p0_radio_postamble[][5] = { 486 /* Addr 5G_HT20 5G_HT40 2G_HT40 2G_HT20 */ 487 {0x00016098, 0xd2dd5554, 0xd2dd5554, 0xc4128f5c, 0xc4128f5c}, 488 {0x0001609c, 0x0a566f3a, 0x0a566f3a, 0x0fd08f25, 0x0fd08f25}, 489 {0x000160ac, 0xa4647c00, 0xa4647c00, 0x24646800, 0x24646800}, 490 {0x000160b0, 0x01885f52, 0x01885f52, 0x00fe7f46, 0x00fe7f46}, 491 {0x00016104, 0xb7a00001, 0xb7a00001, 0xfff80005, 0xfff80005}, 492 {0x0001610c, 0xc0000000, 0xc0000000, 0x00000000, 0x00000000}, 493 {0x00016140, 0x10804008, 0x10804008, 0x50804000, 0x50804000}, 494 {0x00016504, 0xb7a00001, 0xb7a00001, 0xfff80001, 0xfff80001}, 495 {0x0001650c, 0xc0000000, 0xc0000000, 0x00000000, 0x00000000}, 496 {0x00016540, 0x10804008, 0x10804008, 0x50804000, 0x50804000}, 497 }; 498 499 static const u32 qca953x_1p0_modes_xpa_tx_gain_table[][2] = { 500 /* Addr allmodes */ 501 {0x0000a2dc, 0xfffd5aaa}, 502 {0x0000a2e0, 0xfffe9ccc}, 503 {0x0000a2e4, 0xffffe0f0}, 504 {0x0000a2e8, 0xfffcff00}, 505 {0x0000a410, 0x000050da}, 506 {0x0000a500, 0x00000000}, 507 {0x0000a504, 0x04000002}, 508 {0x0000a508, 0x08000004}, 509 {0x0000a50c, 0x0c000006}, 510 {0x0000a510, 0x0f00000a}, 511 {0x0000a514, 0x1300000c}, 512 {0x0000a518, 0x1700000e}, 513 {0x0000a51c, 0x1b000064}, 514 {0x0000a520, 0x1f000242}, 515 {0x0000a524, 0x23000229}, 516 {0x0000a528, 0x270002a2}, 517 {0x0000a52c, 0x2c001203}, 518 {0x0000a530, 0x30001803}, 519 {0x0000a534, 0x33000881}, 520 {0x0000a538, 0x38001809}, 521 {0x0000a53c, 0x3a000814}, 522 {0x0000a540, 0x3f001a0c}, 523 {0x0000a544, 0x43001a0e}, 524 {0x0000a548, 0x46001812}, 525 {0x0000a54c, 0x49001884}, 526 {0x0000a550, 0x4d001e84}, 527 {0x0000a554, 0x50001e69}, 528 {0x0000a558, 0x550006f4}, 529 {0x0000a55c, 0x59000ad3}, 530 {0x0000a560, 0x5e000ad5}, 531 {0x0000a564, 0x61001ced}, 532 {0x0000a568, 0x660018d4}, 533 {0x0000a56c, 0x660018d4}, 534 {0x0000a570, 0x660018d4}, 535 {0x0000a574, 0x660018d4}, 536 {0x0000a578, 0x660018d4}, 537 {0x0000a57c, 0x660018d4}, 538 {0x0000a600, 0x00000000}, 539 {0x0000a604, 0x00000000}, 540 {0x0000a608, 0x00000000}, 541 {0x0000a60c, 0x03804000}, 542 {0x0000a610, 0x0300ca02}, 543 {0x0000a614, 0x00000e04}, 544 {0x0000a618, 0x03014000}, 545 {0x0000a61c, 0x00000000}, 546 {0x0000a620, 0x00000000}, 547 {0x0000a624, 0x03014000}, 548 {0x0000a628, 0x03804c05}, 549 {0x0000a62c, 0x0701de06}, 550 {0x0000a630, 0x07819c07}, 551 {0x0000a634, 0x0701dc07}, 552 {0x0000a638, 0x0701dc07}, 553 {0x0000a63c, 0x0701dc07}, 554 {0x0000b2dc, 0xfffd5aaa}, 555 {0x0000b2e0, 0xfffe9ccc}, 556 {0x0000b2e4, 0xffffe0f0}, 557 {0x0000b2e8, 0xfffcff00}, 558 {0x00016044, 0x010002d4}, 559 {0x00016048, 0x66482400}, 560 {0x00016280, 0x01000015}, 561 {0x00016444, 0x010002d4}, 562 {0x00016448, 0x66482400}, 563 }; 564 565 static const u32 qca953x_1p0_modes_no_xpa_tx_gain_table[][2] = { 566 /* Addr allmodes */ 567 {0x0000a2dc, 0xffd5f552}, 568 {0x0000a2e0, 0xffe60664}, 569 {0x0000a2e4, 0xfff80780}, 570 {0x0000a2e8, 0xfffff800}, 571 {0x0000a410, 0x000050d6}, 572 {0x0000a500, 0x00060020}, 573 {0x0000a504, 0x04060060}, 574 {0x0000a508, 0x080600a0}, 575 {0x0000a50c, 0x0c068020}, 576 {0x0000a510, 0x10068060}, 577 {0x0000a514, 0x140680a0}, 578 {0x0000a518, 0x18090040}, 579 {0x0000a51c, 0x1b090080}, 580 {0x0000a520, 0x1f0900c0}, 581 {0x0000a524, 0x240c0041}, 582 {0x0000a528, 0x280d0021}, 583 {0x0000a52c, 0x2d0f0061}, 584 {0x0000a530, 0x310f00a1}, 585 {0x0000a534, 0x350e00a2}, 586 {0x0000a538, 0x360e80a2}, 587 {0x0000a53c, 0x380f00a2}, 588 {0x0000a540, 0x3b0e00a3}, 589 {0x0000a544, 0x3d110083}, 590 {0x0000a548, 0x3e1100a3}, 591 {0x0000a54c, 0x401100e3}, 592 {0x0000a550, 0x421380e3}, 593 {0x0000a554, 0x431780e3}, 594 {0x0000a558, 0x461f80e3}, 595 {0x0000a55c, 0x461f80e3}, 596 {0x0000a560, 0x461f80e3}, 597 {0x0000a564, 0x461f80e3}, 598 {0x0000a568, 0x461f80e3}, 599 {0x0000a56c, 0x461f80e3}, 600 {0x0000a570, 0x461f80e3}, 601 {0x0000a574, 0x461f80e3}, 602 {0x0000a578, 0x461f80e3}, 603 {0x0000a57c, 0x461f80e3}, 604 {0x0000a600, 0x00000000}, 605 {0x0000a604, 0x00000000}, 606 {0x0000a608, 0x00000000}, 607 {0x0000a60c, 0x00804201}, 608 {0x0000a610, 0x01008201}, 609 {0x0000a614, 0x0180c402}, 610 {0x0000a618, 0x0180c603}, 611 {0x0000a61c, 0x0180c603}, 612 {0x0000a620, 0x01c10603}, 613 {0x0000a624, 0x01c10704}, 614 {0x0000a628, 0x02c18b05}, 615 {0x0000a62c, 0x0301cc07}, 616 {0x0000a630, 0x0301cc07}, 617 {0x0000a634, 0x0301cc07}, 618 {0x0000a638, 0x0301cc07}, 619 {0x0000a63c, 0x0301cc07}, 620 {0x0000b2dc, 0xffd5f552}, 621 {0x0000b2e0, 0xffe60664}, 622 {0x0000b2e4, 0xfff80780}, 623 {0x0000b2e8, 0xfffff800}, 624 {0x00016044, 0x049242db}, 625 {0x00016048, 0x6c927a70}, 626 {0x00016444, 0x049242db}, 627 {0x00016448, 0x6c927a70}, 628 }; 629 630 static const u32 qca953x_1p1_modes_no_xpa_tx_gain_table[][2] = { 631 /* Addr allmodes */ 632 {0x0000a2dc, 0xffd5f552}, 633 {0x0000a2e0, 0xffe60664}, 634 {0x0000a2e4, 0xfff80780}, 635 {0x0000a2e8, 0xfffff800}, 636 {0x0000a410, 0x000050de}, 637 {0x0000a500, 0x00000061}, 638 {0x0000a504, 0x04000063}, 639 {0x0000a508, 0x08000065}, 640 {0x0000a50c, 0x0c000261}, 641 {0x0000a510, 0x10000263}, 642 {0x0000a514, 0x14000265}, 643 {0x0000a518, 0x18000482}, 644 {0x0000a51c, 0x1b000484}, 645 {0x0000a520, 0x1f000486}, 646 {0x0000a524, 0x240008c2}, 647 {0x0000a528, 0x28000cc1}, 648 {0x0000a52c, 0x2d000ce3}, 649 {0x0000a530, 0x31000ce5}, 650 {0x0000a534, 0x350010e5}, 651 {0x0000a538, 0x360012e5}, 652 {0x0000a53c, 0x380014e5}, 653 {0x0000a540, 0x3b0018e5}, 654 {0x0000a544, 0x3d001d04}, 655 {0x0000a548, 0x3e001d05}, 656 {0x0000a54c, 0x40001d07}, 657 {0x0000a550, 0x42001f27}, 658 {0x0000a554, 0x43001f67}, 659 {0x0000a558, 0x46001fe7}, 660 {0x0000a55c, 0x47001f2b}, 661 {0x0000a560, 0x49001f0d}, 662 {0x0000a564, 0x4b001ed2}, 663 {0x0000a568, 0x4c001ed4}, 664 {0x0000a56c, 0x4e001f15}, 665 {0x0000a570, 0x4f001ff6}, 666 {0x0000a574, 0x4f001ff6}, 667 {0x0000a578, 0x4f001ff6}, 668 {0x0000a57c, 0x4f001ff6}, 669 {0x0000a600, 0x00000000}, 670 {0x0000a604, 0x00000000}, 671 {0x0000a608, 0x00000000}, 672 {0x0000a60c, 0x00804201}, 673 {0x0000a610, 0x01008201}, 674 {0x0000a614, 0x0180c402}, 675 {0x0000a618, 0x0180c603}, 676 {0x0000a61c, 0x0180c603}, 677 {0x0000a620, 0x01c10603}, 678 {0x0000a624, 0x01c10704}, 679 {0x0000a628, 0x02c18b05}, 680 {0x0000a62c, 0x02c14c07}, 681 {0x0000a630, 0x01008704}, 682 {0x0000a634, 0x01c10402}, 683 {0x0000a638, 0x0301cc07}, 684 {0x0000a63c, 0x0301cc07}, 685 {0x0000b2dc, 0xffd5f552}, 686 {0x0000b2e0, 0xffe60664}, 687 {0x0000b2e4, 0xfff80780}, 688 {0x0000b2e8, 0xfffff800}, 689 {0x00016044, 0x049242db}, 690 {0x00016048, 0x6c927a70}, 691 {0x00016444, 0x049242db}, 692 {0x00016448, 0x6c927a70}, 693 }; 694 695 static const u32 qca953x_1p1_modes_xpa_tx_gain_table[][2] = { 696 /* Addr allmodes */ 697 {0x0000a2dc, 0xfffb52aa}, 698 {0x0000a2e0, 0xfffd64cc}, 699 {0x0000a2e4, 0xfffe80f0}, 700 {0x0000a2e8, 0xffffff00}, 701 {0x0000a410, 0x000050d5}, 702 {0x0000a500, 0x00000000}, 703 {0x0000a504, 0x04000002}, 704 {0x0000a508, 0x08000004}, 705 {0x0000a50c, 0x0c000006}, 706 {0x0000a510, 0x1000000a}, 707 {0x0000a514, 0x1400000c}, 708 {0x0000a518, 0x1800000e}, 709 {0x0000a51c, 0x1c000048}, 710 {0x0000a520, 0x2000004a}, 711 {0x0000a524, 0x2400004c}, 712 {0x0000a528, 0x2800004e}, 713 {0x0000a52c, 0x2b00024a}, 714 {0x0000a530, 0x2f00024c}, 715 {0x0000a534, 0x3300024e}, 716 {0x0000a538, 0x36000668}, 717 {0x0000a53c, 0x38000669}, 718 {0x0000a540, 0x3a000868}, 719 {0x0000a544, 0x3d00086a}, 720 {0x0000a548, 0x4000086c}, 721 {0x0000a54c, 0x4200086e}, 722 {0x0000a550, 0x43000a6e}, 723 {0x0000a554, 0x43000a6e}, 724 {0x0000a558, 0x43000a6e}, 725 {0x0000a55c, 0x43000a6e}, 726 {0x0000a560, 0x43000a6e}, 727 {0x0000a564, 0x43000a6e}, 728 {0x0000a568, 0x43000a6e}, 729 {0x0000a56c, 0x43000a6e}, 730 {0x0000a570, 0x43000a6e}, 731 {0x0000a574, 0x43000a6e}, 732 {0x0000a578, 0x43000a6e}, 733 {0x0000a57c, 0x43000a6e}, 734 {0x0000a600, 0x00000000}, 735 {0x0000a604, 0x00000000}, 736 {0x0000a608, 0x00000000}, 737 {0x0000a60c, 0x03804000}, 738 {0x0000a610, 0x03804e01}, 739 {0x0000a614, 0x03804e01}, 740 {0x0000a618, 0x03804e01}, 741 {0x0000a61c, 0x04009002}, 742 {0x0000a620, 0x04009002}, 743 {0x0000a624, 0x04009002}, 744 {0x0000a628, 0x04009002}, 745 {0x0000a62c, 0x04009002}, 746 {0x0000a630, 0x04009002}, 747 {0x0000a634, 0x04009002}, 748 {0x0000a638, 0x04009002}, 749 {0x0000a63c, 0x04009002}, 750 {0x0000b2dc, 0xfffb52aa}, 751 {0x0000b2e0, 0xfffd64cc}, 752 {0x0000b2e4, 0xfffe80f0}, 753 {0x0000b2e8, 0xffffff00}, 754 {0x00016044, 0x024922db}, 755 {0x00016048, 0x6c927a70}, 756 {0x00016444, 0x024922db}, 757 {0x00016448, 0x6c927a70}, 758 }; 759 760 static const u32 qca953x_2p0_baseband_core[][2] = { 761 /* Addr allmodes */ 762 {0x00009800, 0xafe68e30}, 763 {0x00009804, 0xfd14e000}, 764 {0x00009808, 0x9c0a9f6b}, 765 {0x0000980c, 0x04900000}, 766 {0x00009814, 0x0280c00a}, 767 {0x00009818, 0x00000000}, 768 {0x0000981c, 0x00020028}, 769 {0x00009834, 0x6400a190}, 770 {0x00009838, 0x0108ecff}, 771 {0x0000983c, 0x14000600}, 772 {0x00009880, 0x201fff00}, 773 {0x00009884, 0x00001042}, 774 {0x000098a4, 0x00200400}, 775 {0x000098b0, 0x32840bbe}, 776 {0x000098bc, 0x00000002}, 777 {0x000098d0, 0x004b6a8e}, 778 {0x000098d4, 0x00000820}, 779 {0x000098dc, 0x00000000}, 780 {0x000098f0, 0x00000000}, 781 {0x000098f4, 0x00000000}, 782 {0x00009c04, 0xff55ff55}, 783 {0x00009c08, 0x0320ff55}, 784 {0x00009c0c, 0x00000000}, 785 {0x00009c10, 0x00000000}, 786 {0x00009c14, 0x00046384}, 787 {0x00009c18, 0x05b6b440}, 788 {0x00009c1c, 0x00b6b440}, 789 {0x00009d00, 0xc080a333}, 790 {0x00009d04, 0x40206c10}, 791 {0x00009d08, 0x009c4060}, 792 {0x00009d0c, 0x9883800a}, 793 {0x00009d10, 0x018848c6}, 794 {0x00009d14, 0x00c0040b}, 795 {0x00009d18, 0x00000000}, 796 {0x00009e08, 0x0038230c}, 797 {0x00009e24, 0x990bb515}, 798 {0x00009e28, 0x0c6f0000}, 799 {0x00009e30, 0x06336f77}, 800 {0x00009e34, 0x6af6532f}, 801 {0x00009e38, 0x0cc80c00}, 802 {0x00009e40, 0x0d261820}, 803 {0x00009e4c, 0x00001004}, 804 {0x00009e50, 0x00ff03f1}, 805 {0x00009fc0, 0x813e4788}, 806 {0x00009fc4, 0x0001efb5}, 807 {0x00009fcc, 0x40000014}, 808 {0x00009fd0, 0x02993b93}, 809 {0x0000a20c, 0x00000000}, 810 {0x0000a220, 0x00000000}, 811 {0x0000a224, 0x00000000}, 812 {0x0000a228, 0x10002310}, 813 {0x0000a23c, 0x00000000}, 814 {0x0000a244, 0x0c000000}, 815 {0x0000a248, 0x00000140}, 816 {0x0000a2a0, 0x00000007}, 817 {0x0000a2c0, 0x00000007}, 818 {0x0000a2c8, 0x00000000}, 819 {0x0000a2d4, 0x00000000}, 820 {0x0000a2ec, 0x00000000}, 821 {0x0000a2f0, 0x00000000}, 822 {0x0000a2f4, 0x00000000}, 823 {0x0000a2f8, 0x00000000}, 824 {0x0000a344, 0x00000000}, 825 {0x0000a34c, 0x00000000}, 826 {0x0000a350, 0x0000a000}, 827 {0x0000a364, 0x00000000}, 828 {0x0000a370, 0x00000000}, 829 {0x0000a390, 0x00000001}, 830 {0x0000a394, 0x00000444}, 831 {0x0000a398, 0x001f0e0f}, 832 {0x0000a39c, 0x0075393f}, 833 {0x0000a3a0, 0xb79f6427}, 834 {0x0000a3a4, 0x000400ff}, 835 {0x0000a3a8, 0x6a6a6a6a}, 836 {0x0000a3ac, 0x6a6a6a6a}, 837 {0x0000a3b0, 0x00c8641a}, 838 {0x0000a3b4, 0x0000001a}, 839 {0x0000a3b8, 0x0088642a}, 840 {0x0000a3bc, 0x000001fa}, 841 {0x0000a3c0, 0x20202020}, 842 {0x0000a3c4, 0x22222220}, 843 {0x0000a3c8, 0x20200020}, 844 {0x0000a3cc, 0x20202020}, 845 {0x0000a3d0, 0x20202020}, 846 {0x0000a3d4, 0x20202020}, 847 {0x0000a3d8, 0x20202020}, 848 {0x0000a3dc, 0x20202020}, 849 {0x0000a3e0, 0x20202020}, 850 {0x0000a3e4, 0x20202020}, 851 {0x0000a3e8, 0x20202020}, 852 {0x0000a3ec, 0x20202020}, 853 {0x0000a3f0, 0x00000000}, 854 {0x0000a3f4, 0x00000000}, 855 {0x0000a3f8, 0x0c9bd380}, 856 {0x0000a3fc, 0x000f0f01}, 857 {0x0000a400, 0x8fa91f01}, 858 {0x0000a404, 0x00000000}, 859 {0x0000a408, 0x0e79e5c6}, 860 {0x0000a40c, 0x00820820}, 861 {0x0000a414, 0x1ce42108}, 862 {0x0000a418, 0x2d001dce}, 863 {0x0000a41c, 0x1ce73908}, 864 {0x0000a420, 0x000001ce}, 865 {0x0000a424, 0x1ce738e7}, 866 {0x0000a428, 0x000001ce}, 867 {0x0000a42c, 0x1ce739ce}, 868 {0x0000a430, 0x1ce739ce}, 869 {0x0000a434, 0x00000000}, 870 {0x0000a438, 0x00001801}, 871 {0x0000a43c, 0x00100000}, 872 {0x0000a444, 0x00000000}, 873 {0x0000a448, 0x05000080}, 874 {0x0000a44c, 0x00000001}, 875 {0x0000a450, 0x00010000}, 876 {0x0000a458, 0x00000000}, 877 {0x0000a644, 0xbfad9d74}, 878 {0x0000a648, 0x0048060a}, 879 {0x0000a64c, 0x00003c37}, 880 {0x0000a670, 0x03020100}, 881 {0x0000a674, 0x09080504}, 882 {0x0000a678, 0x0d0c0b0a}, 883 {0x0000a67c, 0x13121110}, 884 {0x0000a680, 0x31301514}, 885 {0x0000a684, 0x35343332}, 886 {0x0000a688, 0x00000036}, 887 {0x0000a690, 0x08000838}, 888 {0x0000a7cc, 0x00000000}, 889 {0x0000a7d0, 0x00000000}, 890 {0x0000a7d4, 0x00000004}, 891 {0x0000a7dc, 0x00000000}, 892 {0x0000a8d0, 0x004b6a8e}, 893 {0x0000a8d4, 0x00000820}, 894 {0x0000a8dc, 0x00000000}, 895 {0x0000a8f0, 0x00000000}, 896 {0x0000a8f4, 0x00000000}, 897 {0x0000b2d0, 0x00000080}, 898 {0x0000b2d4, 0x00000000}, 899 {0x0000b2ec, 0x00000000}, 900 {0x0000b2f0, 0x00000000}, 901 {0x0000b2f4, 0x00000000}, 902 {0x0000b2f8, 0x00000000}, 903 {0x0000b408, 0x0e79e5c0}, 904 {0x0000b40c, 0x00820820}, 905 {0x0000b420, 0x00000000}, 906 }; 907 908 static const u32 qca953x_2p0_baseband_postamble[][5] = { 909 /* Addr 5G_HT20 5G_HT40 2G_HT40 2G_HT20 */ 910 {0x00009810, 0xd00a8005, 0xd00a8005, 0xd00a8011, 0xd00a8011}, 911 {0x00009820, 0x206a022e, 0x206a022e, 0x206a012e, 0x206a012e}, 912 {0x00009824, 0x5ac640d0, 0x5ac640d0, 0x5ac640d0, 0x5ac640d0}, 913 {0x00009828, 0x06903081, 0x06903081, 0x06903881, 0x06903881}, 914 {0x0000982c, 0x05eea6d4, 0x05eea6d4, 0x05eea6d4, 0x05eea6d4}, 915 {0x00009830, 0x0000059c, 0x0000059c, 0x0000119c, 0x0000119c}, 916 {0x00009c00, 0x000000c4, 0x000000c4, 0x000000c4, 0x000000c4}, 917 {0x00009e00, 0x0372111a, 0x0372111a, 0x037216a0, 0x037216a0}, 918 {0x00009e04, 0x001c2020, 0x001c2020, 0x001c2020, 0x001c2020}, 919 {0x00009e0c, 0x6c4000e2, 0x6d4000e2, 0x6d4000e2, 0x6c4000e2}, 920 {0x00009e10, 0x7ec88d2e, 0x7ec88d2e, 0x7ec84d2e, 0x7ec84d2e}, 921 {0x00009e14, 0x37b95d5e, 0x37b9605e, 0x3379605e, 0x33795d5e}, 922 {0x00009e18, 0x00000000, 0x00000000, 0x00000000, 0x00000000}, 923 {0x00009e1c, 0x0001cf9c, 0x0001cf9c, 0x00021f9c, 0x00021f9c}, 924 {0x00009e20, 0x000003b5, 0x000003b5, 0x000003ce, 0x000003ce}, 925 {0x00009e2c, 0x0000001c, 0x0000001c, 0x00000021, 0x00000021}, 926 {0x00009e3c, 0xcfa10820, 0xcfa10820, 0xcf946222, 0xcf946222}, 927 {0x00009e44, 0xfe321e27, 0xfe321e27, 0xfe291e27, 0xfe291e27}, 928 {0x00009e48, 0x5030201a, 0x5030201a, 0x50302012, 0x50302012}, 929 {0x00009fc8, 0x0003f000, 0x0003f000, 0x0001a000, 0x0001a000}, 930 {0x0000a204, 0x005c0ec0, 0x005c0ec4, 0x005c0ec4, 0x005c0ec0}, 931 {0x0000a208, 0x00000104, 0x00000104, 0x00000004, 0x00000004}, 932 {0x0000a22c, 0x07e26a2f, 0x07e26a2f, 0x01026a2f, 0x01026a2f}, 933 {0x0000a230, 0x0000000a, 0x00000014, 0x00000016, 0x0000000b}, 934 {0x0000a234, 0x00000fff, 0x10000fff, 0x10000fff, 0x00000fff}, 935 {0x0000a238, 0xffb01018, 0xffb01018, 0xffb01018, 0xffb01018}, 936 {0x0000a250, 0x00000000, 0x00000000, 0x00000210, 0x00000108}, 937 {0x0000a254, 0x000007d0, 0x00000fa0, 0x00001130, 0x00000898}, 938 {0x0000a258, 0x02020002, 0x02020002, 0x02020002, 0x02020002}, 939 {0x0000a25c, 0x01000e0e, 0x01000e0e, 0x01010e0e, 0x01010e0e}, 940 {0x0000a260, 0x0a021501, 0x0a021501, 0x3a021501, 0x3a021501}, 941 {0x0000a264, 0x00000e0e, 0x00000e0e, 0x01000e0e, 0x01000e0e}, 942 {0x0000a280, 0x00000007, 0x00000007, 0x0000000b, 0x0000000b}, 943 {0x0000a284, 0x00000000, 0x00000000, 0x00000010, 0x00000010}, 944 {0x0000a288, 0x00000110, 0x00000110, 0x00000110, 0x00000110}, 945 {0x0000a28c, 0x00022222, 0x00022222, 0x00022222, 0x00022222}, 946 {0x0000a2c4, 0x00158d18, 0x00158d18, 0x00158d18, 0x00158d18}, 947 {0x0000a2cc, 0x18c50033, 0x18c43433, 0x18c41033, 0x18c44c33}, 948 {0x0000a2d0, 0x00041982, 0x00041982, 0x00041982, 0x00041982}, 949 {0x0000a2d8, 0x7999a83b, 0x7999a83b, 0x7999a83b, 0x7999a83b}, 950 {0x0000a358, 0x00000000, 0x00000000, 0x00000000, 0x00000000}, 951 {0x0000a830, 0x0000019c, 0x0000019c, 0x0000019c, 0x0000019c}, 952 {0x0000ae04, 0x001c0000, 0x001c0000, 0x001c0000, 0x001c0000}, 953 {0x0000ae18, 0x00000000, 0x00000000, 0x00000000, 0x00000000}, 954 {0x0000ae1c, 0x0000019c, 0x0000019c, 0x0000019c, 0x0000019c}, 955 {0x0000ae20, 0x000001b5, 0x000001b5, 0x000001ce, 0x000001ce}, 956 {0x0000b284, 0x00000000, 0x00000000, 0x00000010, 0x00000010}, 957 }; 958 959 static const u32 qca953x_2p0_common_wo_xlna_rx_gain_table[][2] = { 960 /* Addr allmodes */ 961 {0x0000a000, 0x00010000}, 962 {0x0000a004, 0x00030002}, 963 {0x0000a008, 0x00050004}, 964 {0x0000a00c, 0x00810080}, 965 {0x0000a010, 0x00830082}, 966 {0x0000a014, 0x01810180}, 967 {0x0000a018, 0x01830182}, 968 {0x0000a01c, 0x01850184}, 969 {0x0000a020, 0x01890188}, 970 {0x0000a024, 0x018b018a}, 971 {0x0000a028, 0x018d018c}, 972 {0x0000a02c, 0x03820190}, 973 {0x0000a030, 0x03840383}, 974 {0x0000a034, 0x03880385}, 975 {0x0000a038, 0x038a0389}, 976 {0x0000a03c, 0x038c038b}, 977 {0x0000a040, 0x0390038d}, 978 {0x0000a044, 0x03920391}, 979 {0x0000a048, 0x03940393}, 980 {0x0000a04c, 0x03960395}, 981 {0x0000a050, 0x00000000}, 982 {0x0000a054, 0x00000000}, 983 {0x0000a058, 0x00000000}, 984 {0x0000a05c, 0x00000000}, 985 {0x0000a060, 0x00000000}, 986 {0x0000a064, 0x00000000}, 987 {0x0000a068, 0x00000000}, 988 {0x0000a06c, 0x00000000}, 989 {0x0000a070, 0x00000000}, 990 {0x0000a074, 0x00000000}, 991 {0x0000a078, 0x00000000}, 992 {0x0000a07c, 0x00000000}, 993 {0x0000a080, 0x29292929}, 994 {0x0000a084, 0x29292929}, 995 {0x0000a088, 0x29292929}, 996 {0x0000a08c, 0x29292929}, 997 {0x0000a090, 0x22292929}, 998 {0x0000a094, 0x1d1d2222}, 999 {0x0000a098, 0x0c111117}, 1000 {0x0000a09c, 0x00030303}, 1001 {0x0000a0a0, 0x00000000}, 1002 {0x0000a0a4, 0x00000000}, 1003 {0x0000a0a8, 0x00000000}, 1004 {0x0000a0ac, 0x00000000}, 1005 {0x0000a0b0, 0x00000000}, 1006 {0x0000a0b4, 0x00000000}, 1007 {0x0000a0b8, 0x00000000}, 1008 {0x0000a0bc, 0x00000000}, 1009 {0x0000a0c0, 0x001f0000}, 1010 {0x0000a0c4, 0x01000101}, 1011 {0x0000a0c8, 0x011e011f}, 1012 {0x0000a0cc, 0x011c011d}, 1013 {0x0000a0d0, 0x02030204}, 1014 {0x0000a0d4, 0x02010202}, 1015 {0x0000a0d8, 0x021f0200}, 1016 {0x0000a0dc, 0x0302021e}, 1017 {0x0000a0e0, 0x03000301}, 1018 {0x0000a0e4, 0x031e031f}, 1019 {0x0000a0e8, 0x0402031d}, 1020 {0x0000a0ec, 0x04000401}, 1021 {0x0000a0f0, 0x041e041f}, 1022 {0x0000a0f4, 0x0502041d}, 1023 {0x0000a0f8, 0x05000501}, 1024 {0x0000a0fc, 0x051e051f}, 1025 {0x0000a100, 0x06010602}, 1026 {0x0000a104, 0x061f0600}, 1027 {0x0000a108, 0x061d061e}, 1028 {0x0000a10c, 0x07020703}, 1029 {0x0000a110, 0x07000701}, 1030 {0x0000a114, 0x00000000}, 1031 {0x0000a118, 0x00000000}, 1032 {0x0000a11c, 0x00000000}, 1033 {0x0000a120, 0x00000000}, 1034 {0x0000a124, 0x00000000}, 1035 {0x0000a128, 0x00000000}, 1036 {0x0000a12c, 0x00000000}, 1037 {0x0000a130, 0x00000000}, 1038 {0x0000a134, 0x00000000}, 1039 {0x0000a138, 0x00000000}, 1040 {0x0000a13c, 0x00000000}, 1041 {0x0000a140, 0x001f0000}, 1042 {0x0000a144, 0x01000101}, 1043 {0x0000a148, 0x011e011f}, 1044 {0x0000a14c, 0x011c011d}, 1045 {0x0000a150, 0x02030204}, 1046 {0x0000a154, 0x02010202}, 1047 {0x0000a158, 0x021f0200}, 1048 {0x0000a15c, 0x0302021e}, 1049 {0x0000a160, 0x03000301}, 1050 {0x0000a164, 0x031e031f}, 1051 {0x0000a168, 0x0402031d}, 1052 {0x0000a16c, 0x04000401}, 1053 {0x0000a170, 0x041e041f}, 1054 {0x0000a174, 0x0502041d}, 1055 {0x0000a178, 0x05000501}, 1056 {0x0000a17c, 0x051e051f}, 1057 {0x0000a180, 0x06010602}, 1058 {0x0000a184, 0x061f0600}, 1059 {0x0000a188, 0x061d061e}, 1060 {0x0000a18c, 0x07020703}, 1061 {0x0000a190, 0x07000701}, 1062 {0x0000a194, 0x00000000}, 1063 {0x0000a198, 0x00000000}, 1064 {0x0000a19c, 0x00000000}, 1065 {0x0000a1a0, 0x00000000}, 1066 {0x0000a1a4, 0x00000000}, 1067 {0x0000a1a8, 0x00000000}, 1068 {0x0000a1ac, 0x00000000}, 1069 {0x0000a1b0, 0x00000000}, 1070 {0x0000a1b4, 0x00000000}, 1071 {0x0000a1b8, 0x00000000}, 1072 {0x0000a1bc, 0x00000000}, 1073 {0x0000a1c0, 0x00000000}, 1074 {0x0000a1c4, 0x00000000}, 1075 {0x0000a1c8, 0x00000000}, 1076 {0x0000a1cc, 0x00000000}, 1077 {0x0000a1d0, 0x00000000}, 1078 {0x0000a1d4, 0x00000000}, 1079 {0x0000a1d8, 0x00000000}, 1080 {0x0000a1dc, 0x00000000}, 1081 {0x0000a1e0, 0x00000000}, 1082 {0x0000a1e4, 0x00000000}, 1083 {0x0000a1e8, 0x00000000}, 1084 {0x0000a1ec, 0x00000000}, 1085 {0x0000a1f0, 0x00000396}, 1086 {0x0000a1f4, 0x00000396}, 1087 {0x0000a1f8, 0x00000396}, 1088 {0x0000a1fc, 0x00000196}, 1089 {0x0000b000, 0x00010000}, 1090 {0x0000b004, 0x00030002}, 1091 {0x0000b008, 0x00050004}, 1092 {0x0000b00c, 0x00810080}, 1093 {0x0000b010, 0x00830082}, 1094 {0x0000b014, 0x01810180}, 1095 {0x0000b018, 0x01830182}, 1096 {0x0000b01c, 0x01850184}, 1097 {0x0000b020, 0x02810280}, 1098 {0x0000b024, 0x02830282}, 1099 {0x0000b028, 0x02850284}, 1100 {0x0000b02c, 0x02890288}, 1101 {0x0000b030, 0x028b028a}, 1102 {0x0000b034, 0x0388028c}, 1103 {0x0000b038, 0x038a0389}, 1104 {0x0000b03c, 0x038c038b}, 1105 {0x0000b040, 0x0390038d}, 1106 {0x0000b044, 0x03920391}, 1107 {0x0000b048, 0x03940393}, 1108 {0x0000b04c, 0x03960395}, 1109 {0x0000b050, 0x00000000}, 1110 {0x0000b054, 0x00000000}, 1111 {0x0000b058, 0x00000000}, 1112 {0x0000b05c, 0x00000000}, 1113 {0x0000b060, 0x00000000}, 1114 {0x0000b064, 0x00000000}, 1115 {0x0000b068, 0x00000000}, 1116 {0x0000b06c, 0x00000000}, 1117 {0x0000b070, 0x00000000}, 1118 {0x0000b074, 0x00000000}, 1119 {0x0000b078, 0x00000000}, 1120 {0x0000b07c, 0x00000000}, 1121 {0x0000b080, 0x32323232}, 1122 {0x0000b084, 0x2f2f3232}, 1123 {0x0000b088, 0x23282a2d}, 1124 {0x0000b08c, 0x1c1e2123}, 1125 {0x0000b090, 0x14171919}, 1126 {0x0000b094, 0x0e0e1214}, 1127 {0x0000b098, 0x03050707}, 1128 {0x0000b09c, 0x00030303}, 1129 {0x0000b0a0, 0x00000000}, 1130 {0x0000b0a4, 0x00000000}, 1131 {0x0000b0a8, 0x00000000}, 1132 {0x0000b0ac, 0x00000000}, 1133 {0x0000b0b0, 0x00000000}, 1134 {0x0000b0b4, 0x00000000}, 1135 {0x0000b0b8, 0x00000000}, 1136 {0x0000b0bc, 0x00000000}, 1137 {0x0000b0c0, 0x003f0020}, 1138 {0x0000b0c4, 0x00400041}, 1139 {0x0000b0c8, 0x0140005f}, 1140 {0x0000b0cc, 0x0160015f}, 1141 {0x0000b0d0, 0x017e017f}, 1142 {0x0000b0d4, 0x02410242}, 1143 {0x0000b0d8, 0x025f0240}, 1144 {0x0000b0dc, 0x027f0260}, 1145 {0x0000b0e0, 0x0341027e}, 1146 {0x0000b0e4, 0x035f0340}, 1147 {0x0000b0e8, 0x037f0360}, 1148 {0x0000b0ec, 0x04400441}, 1149 {0x0000b0f0, 0x0460045f}, 1150 {0x0000b0f4, 0x0541047f}, 1151 {0x0000b0f8, 0x055f0540}, 1152 {0x0000b0fc, 0x057f0560}, 1153 {0x0000b100, 0x06400641}, 1154 {0x0000b104, 0x0660065f}, 1155 {0x0000b108, 0x067e067f}, 1156 {0x0000b10c, 0x07410742}, 1157 {0x0000b110, 0x075f0740}, 1158 {0x0000b114, 0x077f0760}, 1159 {0x0000b118, 0x07800781}, 1160 {0x0000b11c, 0x07a0079f}, 1161 {0x0000b120, 0x07c107bf}, 1162 {0x0000b124, 0x000007c0}, 1163 {0x0000b128, 0x00000000}, 1164 {0x0000b12c, 0x00000000}, 1165 {0x0000b130, 0x00000000}, 1166 {0x0000b134, 0x00000000}, 1167 {0x0000b138, 0x00000000}, 1168 {0x0000b13c, 0x00000000}, 1169 {0x0000b140, 0x003f0020}, 1170 {0x0000b144, 0x00400041}, 1171 {0x0000b148, 0x0140005f}, 1172 {0x0000b14c, 0x0160015f}, 1173 {0x0000b150, 0x017e017f}, 1174 {0x0000b154, 0x02410242}, 1175 {0x0000b158, 0x025f0240}, 1176 {0x0000b15c, 0x027f0260}, 1177 {0x0000b160, 0x0341027e}, 1178 {0x0000b164, 0x035f0340}, 1179 {0x0000b168, 0x037f0360}, 1180 {0x0000b16c, 0x04400441}, 1181 {0x0000b170, 0x0460045f}, 1182 {0x0000b174, 0x0541047f}, 1183 {0x0000b178, 0x055f0540}, 1184 {0x0000b17c, 0x057f0560}, 1185 {0x0000b180, 0x06400641}, 1186 {0x0000b184, 0x0660065f}, 1187 {0x0000b188, 0x067e067f}, 1188 {0x0000b18c, 0x07410742}, 1189 {0x0000b190, 0x075f0740}, 1190 {0x0000b194, 0x077f0760}, 1191 {0x0000b198, 0x07800781}, 1192 {0x0000b19c, 0x07a0079f}, 1193 {0x0000b1a0, 0x07c107bf}, 1194 {0x0000b1a4, 0x000007c0}, 1195 {0x0000b1a8, 0x00000000}, 1196 {0x0000b1ac, 0x00000000}, 1197 {0x0000b1b0, 0x00000000}, 1198 {0x0000b1b4, 0x00000000}, 1199 {0x0000b1b8, 0x00000000}, 1200 {0x0000b1bc, 0x00000000}, 1201 {0x0000b1c0, 0x00000000}, 1202 {0x0000b1c4, 0x00000000}, 1203 {0x0000b1c8, 0x00000000}, 1204 {0x0000b1cc, 0x00000000}, 1205 {0x0000b1d0, 0x00000000}, 1206 {0x0000b1d4, 0x00000000}, 1207 {0x0000b1d8, 0x00000000}, 1208 {0x0000b1dc, 0x00000000}, 1209 {0x0000b1e0, 0x00000000}, 1210 {0x0000b1e4, 0x00000000}, 1211 {0x0000b1e8, 0x00000000}, 1212 {0x0000b1ec, 0x00000000}, 1213 {0x0000b1f0, 0x00000396}, 1214 {0x0000b1f4, 0x00000396}, 1215 {0x0000b1f8, 0x00000396}, 1216 {0x0000b1fc, 0x00000196}, 1217 }; 1218 1219 static const u32 qca953x_2p0_common_wo_xlna_rx_gain_bounds[][5] = { 1220 /* Addr 5G_HT20 5G_HT40 2G_HT40 2G_HT20 */ 1221 {0x00009e44, 0xfe321e27, 0xfe321e27, 0xfe291e27, 0xfe291e27}, 1222 {0x00009e48, 0x5030201a, 0x5030201a, 0x50302012, 0x50302012}, 1223 }; 1224 1225 static const u32 qca953x_2p0_modes_xpa_tx_gain_table[][2] = { 1226 /* Addr allmodes */ 1227 {0x0000a2dc, 0xfffb52aa}, 1228 {0x0000a2e0, 0xfffd64cc}, 1229 {0x0000a2e4, 0xfffe80f0}, 1230 {0x0000a2e8, 0xffffff00}, 1231 {0x0000a410, 0x000050d5}, 1232 {0x0000a500, 0x00000000}, 1233 {0x0000a504, 0x04000002}, 1234 {0x0000a508, 0x08000004}, 1235 {0x0000a50c, 0x0c000006}, 1236 {0x0000a510, 0x1000000a}, 1237 {0x0000a514, 0x1400000c}, 1238 {0x0000a518, 0x1800000e}, 1239 {0x0000a51c, 0x1c000048}, 1240 {0x0000a520, 0x2000004a}, 1241 {0x0000a524, 0x2400004c}, 1242 {0x0000a528, 0x2800004e}, 1243 {0x0000a52c, 0x2b00024a}, 1244 {0x0000a530, 0x2f00024c}, 1245 {0x0000a534, 0x3300024e}, 1246 {0x0000a538, 0x36000668}, 1247 {0x0000a53c, 0x38000669}, 1248 {0x0000a540, 0x3a000868}, 1249 {0x0000a544, 0x3d00086a}, 1250 {0x0000a548, 0x4000086c}, 1251 {0x0000a54c, 0x4200086e}, 1252 {0x0000a550, 0x43000a6e}, 1253 {0x0000a554, 0x43000a6e}, 1254 {0x0000a558, 0x43000a6e}, 1255 {0x0000a55c, 0x43000a6e}, 1256 {0x0000a560, 0x43000a6e}, 1257 {0x0000a564, 0x43000a6e}, 1258 {0x0000a568, 0x43000a6e}, 1259 {0x0000a56c, 0x43000a6e}, 1260 {0x0000a570, 0x43000a6e}, 1261 {0x0000a574, 0x43000a6e}, 1262 {0x0000a578, 0x43000a6e}, 1263 {0x0000a57c, 0x43000a6e}, 1264 {0x0000a600, 0x00000000}, 1265 {0x0000a604, 0x00000000}, 1266 {0x0000a608, 0x00000000}, 1267 {0x0000a60c, 0x03804000}, 1268 {0x0000a610, 0x03804e01}, 1269 {0x0000a614, 0x03804e01}, 1270 {0x0000a618, 0x03804e01}, 1271 {0x0000a61c, 0x04009002}, 1272 {0x0000a620, 0x04009002}, 1273 {0x0000a624, 0x04009002}, 1274 {0x0000a628, 0x04009002}, 1275 {0x0000a62c, 0x04009002}, 1276 {0x0000a630, 0x04009002}, 1277 {0x0000a634, 0x04009002}, 1278 {0x0000a638, 0x04009002}, 1279 {0x0000a63c, 0x04009002}, 1280 {0x0000b2dc, 0xfffb52aa}, 1281 {0x0000b2e0, 0xfffd64cc}, 1282 {0x0000b2e4, 0xfffe80f0}, 1283 {0x0000b2e8, 0xffffff00}, 1284 {0x00016044, 0x024922db}, 1285 {0x00016048, 0x6c927a70}, 1286 {0x00016444, 0x024922db}, 1287 {0x00016448, 0x6c927a70}, 1288 }; 1289 1290 static const u32 qca953x_2p0_modes_no_xpa_tx_gain_table[][2] = { 1291 /* Addr allmodes */ 1292 {0x0000a2dc, 0xffd5f552}, 1293 {0x0000a2e0, 0xffe60664}, 1294 {0x0000a2e4, 0xfff80780}, 1295 {0x0000a2e8, 0xfffff800}, 1296 {0x0000a410, 0x000050de}, 1297 {0x0000a500, 0x00000061}, 1298 {0x0000a504, 0x04000063}, 1299 {0x0000a508, 0x08000065}, 1300 {0x0000a50c, 0x0c000261}, 1301 {0x0000a510, 0x10000263}, 1302 {0x0000a514, 0x14000265}, 1303 {0x0000a518, 0x18000482}, 1304 {0x0000a51c, 0x1b000484}, 1305 {0x0000a520, 0x1f000486}, 1306 {0x0000a524, 0x240008c2}, 1307 {0x0000a528, 0x28000cc1}, 1308 {0x0000a52c, 0x2d000ce3}, 1309 {0x0000a530, 0x31000ce5}, 1310 {0x0000a534, 0x350010e5}, 1311 {0x0000a538, 0x360012e5}, 1312 {0x0000a53c, 0x380014e5}, 1313 {0x0000a540, 0x3b0018e5}, 1314 {0x0000a544, 0x3d001d04}, 1315 {0x0000a548, 0x3e001d05}, 1316 {0x0000a54c, 0x40001d07}, 1317 {0x0000a550, 0x42001f27}, 1318 {0x0000a554, 0x43001f67}, 1319 {0x0000a558, 0x46001fe7}, 1320 {0x0000a55c, 0x47001f2b}, 1321 {0x0000a560, 0x49001f0d}, 1322 {0x0000a564, 0x4b001ed2}, 1323 {0x0000a568, 0x4c001ed4}, 1324 {0x0000a56c, 0x4e001f15}, 1325 {0x0000a570, 0x4f001ff6}, 1326 {0x0000a574, 0x4f001ff6}, 1327 {0x0000a578, 0x4f001ff6}, 1328 {0x0000a57c, 0x4f001ff6}, 1329 {0x0000a600, 0x00000000}, 1330 {0x0000a604, 0x00000000}, 1331 {0x0000a608, 0x00000000}, 1332 {0x0000a60c, 0x00804201}, 1333 {0x0000a610, 0x01008201}, 1334 {0x0000a614, 0x0180c402}, 1335 {0x0000a618, 0x0180c603}, 1336 {0x0000a61c, 0x0180c603}, 1337 {0x0000a620, 0x01c10603}, 1338 {0x0000a624, 0x01c10704}, 1339 {0x0000a628, 0x02c18b05}, 1340 {0x0000a62c, 0x02c14c07}, 1341 {0x0000a630, 0x01008704}, 1342 {0x0000a634, 0x01c10402}, 1343 {0x0000a638, 0x0301cc07}, 1344 {0x0000a63c, 0x0301cc07}, 1345 {0x0000b2dc, 0xffd5f552}, 1346 {0x0000b2e0, 0xffe60664}, 1347 {0x0000b2e4, 0xfff80780}, 1348 {0x0000b2e8, 0xfffff800}, 1349 {0x00016044, 0x049242db}, 1350 {0x00016048, 0x6c927a70}, 1351 {0x00016444, 0x049242db}, 1352 {0x00016448, 0x6c927a70}, 1353 }; 1354 1355 #endif /* INITVALS_953X_H */ 1356