/* $OpenBSD: ar9280reg.h,v 1.6 2012/10/20 09:54:20 stsp Exp $ */ /*- * Copyright (c) 2009 Damien Bergamini * Copyright (c) 2008-2009 Atheros Communications Inc. * * Permission to use, copy, modify, and/or distribute this software for any * purpose with or without fee is hereby granted, provided that the above * copyright notice and this permission notice appear in all copies. * * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ #define AR9280_MAX_CHAINS 2 #define AR9280_PD_GAIN_BOUNDARY_DEFAULT 56 #define AR9280_PHY_CCA_MAX_GOOD_VALUE (-112) #define AR9280_PHY_SYNTH_CONTROL 0x9874 /* Bits for AR9280_PHY_SYNTH_CONTROL. */ #define AR9280_BMODE 0x20000000 #define AR9280_FRACMODE 0x10000000 #define AR9280_AMODE_REFSEL_M 0x0c000000 #define AR9280_AMODE_REFSEL_S 26 /* * NB: The AR9280 uses the same ROM layout than the AR5416. */ /* Macro to "pack" registers to 16-bit to save some .rodata space. */ #define P(x) (x) /* * AR9280 2.0 initialization values. */ static const uint16_t ar9280_2_0_regs[] = { P(0x01030), P(0x01070), P(0x010b0), P(0x010f0), P(0x08014), P(0x0801c), P(0x08120), P(0x081d0), P(0x08318), P(0x09804), P(0x09820), P(0x09824), P(0x09828), P(0x09834), P(0x09838), P(0x09840), P(0x09844), P(0x09850), P(0x09858), P(0x0985c), P(0x09860), P(0x09864), P(0x09868), P(0x0986c), P(0x09914), P(0x09918), P(0x09924), P(0x09944), P(0x09960), P(0x0a960), P(0x09964), P(0x0c968), P(0x099b8), P(0x099bc), P(0x099c0), P(0x0a204), P(0x0a20c), P(0x0b20c), P(0x0a21c), P(0x0a230), P(0x0a23c), P(0x0a250), P(0x0a358), P(0x0a388), P(0x0a3d8), P(0x07894) }; static const uint32_t ar9280_2_0_vals_5g20[] = { 0x00000230, 0x00000168, 0x00000e60, 0x00000000, 0x03e803e8, 0x128d8027, 0x08f04800, 0x00003210, 0x00003e80, 0x00000300, 0x02020200, 0x01000e0e, 0x0a020001, 0x00000e0e, 0x00000007, 0x206a022e, 0x0372161e, 0x6c4000e2, 0x7ec88d2e, 0x31395d5e, 0x00048d18, 0x0001ce00, 0x5ac640d0, 0x06903081, 0x000007d0, 0x0000000a, 0xd00a8a0b, 0xffbc1010, 0x00000010, 0x00000010, 0x00000210, 0x000003b5, 0x0000001c, 0x00000a00, 0x05eea6d4, 0x00000444, 0x00000014, 0x00000014, 0x1883800a, 0x00000000, 0x13c88000, 0x001ff000, 0x7999aa02, 0x0c000000, 0x00000000, 0x5a508000 }; #ifndef IEEE80211_NO_HT static const uint32_t ar9280_2_0_vals_5g40[] = { 0x00000460, 0x000002d0, 0x00001cc0, 0x00000000, 0x07d007d0, 0x128d804f, 0x08f04800, 0x00003210, 0x00007d00, 0x000003c4, 0x02020200, 0x01000e0e, 0x0a020001, 0x00000e0e, 0x00000007, 0x206a022e, 0x0372161e, 0x6d4000e2, 0x7ec88d2e, 0x3139605e, 0x00048d18, 0x0001ce00, 0x5ac640d0, 0x06903081, 0x00000fa0, 0x00000014, 0xd00a8a0b, 0xffbc1010, 0x00000010, 0x00000010, 0x00000210, 0x000003b5, 0x0000001c, 0x00000a00, 0x05eea6d4, 0x00000444, 0x00000014, 0x00000014, 0x1883800a, 0x00000000, 0x13c88000, 0x001ff000, 0x7999aa02, 0x0c000000, 0x00000000, 0x5a508000 }; static const uint32_t ar9280_2_0_vals_2g40[] = { 0x000002c0, 0x00000318, 0x00007c70, 0x00000000, 0x10801600, 0x12e00057, 0x08f04810, 0x0000320a, 0x00006880, 0x000003c4, 0x02020200, 0x01000e0e, 0x0a020001, 0x00000e0e, 0x00000007, 0x206a012e, 0x037216a0, 0x6d4000e2, 0x7ec84d2e, 0x3139605e, 0x00048d20, 0x0001ce00, 0x5ac640d0, 0x06903881, 0x00001130, 0x00000268, 0xd00a8a0d, 0xffbc1010, 0x00000010, 0x00000010, 0x00000210, 0x000003ce, 0x0000001c, 0x00000c00, 0x05eea6d4, 0x00000444, 0x0001f019, 0x0001f019, 0x1883800a, 0x00000210, 0x13c88001, 0x0004a000, 0x7999aa0e, 0x08000000, 0x00000000, 0x5a508000 }; #endif static const uint32_t ar9280_2_0_vals_2g20[] = { 0x00000160, 0x0000018c, 0x00003e38, 0x00000000, 0x08400b00, 0x12e0002b, 0x08f04810, 0x0000320a, 0x00003440, 0x00000300, 0x02020200, 0x01000e0e, 0x0a020001, 0x00000e0e, 0x00000007, 0x206a012e, 0x037216a0, 0x6c4000e2, 0x7ec84d2e, 0x31395d5e, 0x00048d20, 0x0001ce00, 0x5ac640d0, 0x06903881, 0x00000898, 0x0000000b, 0xd00a8a0d, 0xffbc1010, 0x00000010, 0x00000010, 0x00000210, 0x000003ce, 0x0000001c, 0x00000c00, 0x05eea6d4, 0x00000444, 0x0001f019, 0x0001f019, 0x1883800a, 0x00000108, 0x13c88000, 0x0004a000, 0x7999aa0e, 0x0c000000, 0x00000000, 0x5a508000 }; static const uint16_t ar9280_2_0_cm_regs[] = { P(0x0000c), P(0x00030), P(0x00034), P(0x00040), P(0x00044), P(0x00048), P(0x0004c), P(0x00050), P(0x00054), P(0x00800), P(0x00804), P(0x00808), P(0x0080c), P(0x00810), P(0x00814), P(0x00818), P(0x0081c), P(0x00820), P(0x00824), P(0x01040), P(0x01044), P(0x01048), P(0x0104c), P(0x01050), P(0x01054), P(0x01058), P(0x0105c), P(0x01060), P(0x01064), P(0x01230), P(0x01270), P(0x01038), P(0x01078), P(0x010b8), P(0x010f8), P(0x01138), P(0x01178), P(0x011b8), P(0x011f8), P(0x01238), P(0x01278), P(0x012b8), P(0x012f8), P(0x01338), P(0x01378), P(0x013b8), P(0x013f8), P(0x01438), P(0x01478), P(0x014b8), P(0x014f8), P(0x01538), P(0x01578), P(0x015b8), P(0x015f8), P(0x01638), P(0x01678), P(0x016b8), P(0x016f8), P(0x01738), P(0x01778), P(0x017b8), P(0x017f8), P(0x0103c), P(0x0107c), P(0x010bc), P(0x010fc), P(0x0113c), P(0x0117c), P(0x011bc), P(0x011fc), P(0x0123c), P(0x0127c), P(0x012bc), P(0x012fc), P(0x0133c), P(0x0137c), P(0x013bc), P(0x013fc), P(0x0143c), P(0x0147c), P(0x04030), P(0x0403c), P(0x04024), P(0x04060), P(0x04064), P(0x07010), P(0x07034), P(0x07038), P(0x08004), P(0x08008), P(0x0800c), P(0x08018), P(0x08020), P(0x08038), P(0x0803c), P(0x08048), P(0x08054), P(0x08058), P(0x0805c), P(0x08060), P(0x08064), P(0x08070), P(0x080c0), P(0x080c4), P(0x080c8), P(0x080cc), P(0x080d0), P(0x080d4), P(0x080d8), P(0x080e0), P(0x080e4), P(0x080e8), P(0x080ec), P(0x080f0), P(0x080f4), P(0x080f8), P(0x080fc), P(0x08100), P(0x08104), P(0x08108), P(0x0810c), P(0x08110), P(0x08118), P(0x0811c), P(0x08124), P(0x08128), P(0x0812c), P(0x08130), P(0x08134), P(0x08138), P(0x0813c), P(0x08144), P(0x08168), P(0x0816c), P(0x08170), P(0x08174), P(0x08178), P(0x0817c), P(0x081c0), P(0x081ec), P(0x081f0), P(0x081f4), P(0x081f8), P(0x081fc), P(0x08200), P(0x08204), P(0x08208), P(0x0820c), P(0x08210), P(0x08214), P(0x08218), P(0x0821c), P(0x08220), P(0x08224), P(0x08228), P(0x0822c), P(0x08230), P(0x08234), P(0x08238), P(0x0823c), P(0x08240), P(0x08244), P(0x08248), P(0x0824c), P(0x08250), P(0x08254), P(0x08258), P(0x0825c), P(0x08260), P(0x08264), P(0x08270), P(0x08274), P(0x08278), P(0x0827c), P(0x08284), P(0x08288), P(0x0828c), P(0x08294), P(0x08298), P(0x0829c), P(0x08300), P(0x08314), P(0x08328), P(0x0832c), P(0x08330), P(0x08334), P(0x08338), P(0x0833c), P(0x08340), P(0x08344), P(0x09808), P(0x0980c), P(0x09810), P(0x09814), P(0x0981c), P(0x0982c), P(0x09830), P(0x0983c), P(0x0984c), P(0x0a84c), P(0x09854), P(0x09900), P(0x09904), P(0x09908), P(0x0990c), P(0x09910), P(0x0991c), P(0x09920), P(0x0a920), P(0x09928), P(0x0992c), P(0x09934), P(0x09938), P(0x0993c), P(0x09948), P(0x0994c), P(0x09954), P(0x09958), P(0x09940), P(0x0c95c), P(0x09970), P(0x09974), P(0x09978), P(0x0997c), P(0x09980), P(0x09984), P(0x09988), P(0x0998c), P(0x09990), P(0x09994), P(0x09998), P(0x0999c), P(0x099a0), P(0x099a4), P(0x099a8), P(0x099ac), P(0x099b0), P(0x099b4), P(0x099c4), P(0x099c8), P(0x099cc), P(0x099d0), P(0x099d4), P(0x099d8), P(0x099dc), P(0x099e0), P(0x099e4), P(0x099e8), P(0x099ec), P(0x099f0), P(0x099fc), P(0x0a208), P(0x0a210), P(0x0a214), P(0x0a218), P(0x0a220), P(0x0a224), P(0x0a228), P(0x0a22c), P(0x0a234), P(0x0a238), P(0x0a240), P(0x0a244), P(0x0a248), P(0x0a24c), P(0x0a254), P(0x0a258), P(0x0a25c), P(0x0a260), P(0x0a268), P(0x0a26c), P(0x0b26c), P(0x0d270), P(0x0a278), P(0x0d35c), P(0x0d360), P(0x0d364), P(0x0d368), P(0x0d36c), P(0x0d370), P(0x0d374), P(0x0d378), P(0x0d37c), P(0x0d380), P(0x0d384), P(0x0a38c), P(0x0a390), P(0x0a394), P(0x0a398), P(0x0a39c), P(0x0a3a0), P(0x0a3a4), P(0x0a3a8), P(0x0a3ac), P(0x0a3b0), P(0x0a3b4), P(0x0a3b8), P(0x0a3bc), P(0x0a3c0), P(0x0a3c4), P(0x0a3c8), P(0x0a3cc), P(0x0a3d0), P(0x0a3d4), P(0x0a3dc), P(0x0a3e0), P(0x0a3e4), P(0x0a3e8), P(0x07800), P(0x07804), P(0x07808), P(0x0780c), P(0x07810), P(0x07818), P(0x07824), P(0x07828), P(0x0782c), P(0x07830), P(0x07834), P(0x0783c), P(0x07848), P(0x0784c), P(0x07850), P(0x07854), P(0x07858), P(0x07860), P(0x07864), P(0x07868), P(0x0786c), P(0x07870), P(0x07874), P(0x07878), P(0x0787c), P(0x07880), P(0x07884), P(0x07888), P(0x0788c), P(0x07890), P(0x07898) }; static const uint32_t ar9280_2_0_cm_vals[] = { 0x00000000, 0x00020015, 0x00000005, 0x00000000, 0x00000008, 0x00000008, 0x00000010, 0x00000000, 0x0000001f, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x002ffc0f, 0x002ffc0f, 0x002ffc0f, 0x002ffc0f, 0x002ffc0f, 0x002ffc0f, 0x002ffc0f, 0x002ffc0f, 0x002ffc0f, 0x002ffc0f, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000002, 0x00000002, 0x0000001f, 0x00000000, 0x00000000, 0x00000033, 0x00000002, 0x000004c2, 0x00000000, 0x00000000, 0x00000000, 0x00000700, 0x00000000, 0x00000000, 0x00000000, 0x40000000, 0x00000000, 0x00000000, 0x000fc78f, 0x0000000f, 0x00000000, 0x00000000, 0x2a80001a, 0x05dc01e0, 0x1f402710, 0x01f40000, 0x00001e00, 0x00000000, 0x00400000, 0xffffffff, 0x0000ffff, 0x003f3f3f, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00020000, 0x00020000, 0x00000001, 0x00000052, 0x00000000, 0x00000168, 0x000100aa, 0x00003210, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0xffffffff, 0x00000000, 0x00000000, 0x32143320, 0xfaa4fa50, 0x00000100, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00100000, 0x0010f400, 0x00000100, 0x0001e800, 0x00000000, 0x00000000, 0x00000000, 0x400000ff, 0x00080922, 0x88a00010, 0x00000000, 0x40000000, 0x003e4180, 0x00000000, 0x0000002c, 0x0000002c, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000040, 0x00000000, 0x00000000, 0x00000007, 0x00000302, 0x00000e00, 0x00ff0000, 0x00000000, 0x000107ff, 0x00481043, 0x00000000, 0xafa68e30, 0xfd14e000, 0x9c0a9f6b, 0x00000000, 0x0000a000, 0x00000000, 0x00200400, 0x0040233c, 0x0040233c, 0x00000044, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x01002310, 0x10000fff, 0x04900000, 0x04900000, 0x00000001, 0x00000004, 0x1e1f2022, 0x0a0b0c0d, 0x00000000, 0x9280c00a, 0x00020028, 0x5f3ca3de, 0x2108ecff, 0x14750604, 0x004b6a8e, 0x190fb514, 0x00000000, 0x00000001, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000001, 0x201fff00, 0x006f0000, 0x03051000, 0x00000820, 0x06336f77, 0x6af6532f, 0x08f186c8, 0x00046384, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0xaaaaaaaa, 0x3c466478, 0x0cc80caa, 0x00000000, 0x00001042, 0x803e4788, 0x4080a333, 0x40206c10, 0x009c4060, 0x01834061, 0x00000400, 0x000003b5, 0x233f7180, 0x20202020, 0x20202020, 0x38490a20, 0x00007bb6, 0x0fff3ffc, 0x00000000, 0x00000000, 0x0cdbd380, 0x0f0f0f01, 0xdfa91f01, 0x00000000, 0x0e79e5c6, 0x0e79e5c6, 0x00820820, 0x1ce739ce, 0x07ffffef, 0x0fffffe7, 0x17ffffe5, 0x1fffffe4, 0x37ffffe3, 0x3fffffe3, 0x57ffffe3, 0x5fffffe2, 0x7fffffe2, 0x7f3c7bba, 0xf3307ff0, 0x20202020, 0x20202020, 0x1ce739ce, 0x000001ce, 0x00000001, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000246, 0x20202020, 0x20202020, 0x20202020, 0x1ce739ce, 0x000001ce, 0x00000000, 0x18c43433, 0x00040000, 0xdb005012, 0x04924914, 0x21084210, 0x6d801300, 0x07e41000, 0x00040000, 0xdb005012, 0x04924914, 0x21084210, 0x6d801300, 0x07e40000, 0x00100000, 0x773f0567, 0x54214514, 0x12035828, 0x9259269a, 0x52802000, 0x0a8e370e, 0xc0102850, 0x812d4000, 0x807ec400, 0x001b6db0, 0x00376b63, 0x06db6db6, 0x006d8000, 0xffeffffe, 0xffeffffe, 0x00010000, 0x02060aeb, 0x2a850160 }; static const uint16_t ar9280_2_0_fast_clock_regs[] = { P(0x01030), P(0x01070), P(0x010b0), P(0x08014), P(0x0801c), P(0x08318), P(0x09820), P(0x09824), P(0x09828), P(0x09834), P(0x09844), P(0x09914), P(0x09918) }; static const uint32_t ar9280_2_0_fast_clock_vals_5g20[] = { 0x00000268, 0x0000018c, 0x00000fd0, 0x044c044c, 0x148ec02b, 0x000044c0, 0x02020200, 0x01000f0f, 0x0b020001, 0x00000f0f, 0x03721821, 0x00000898, 0x0000000b }; #ifndef IEEE80211_NO_HT static const uint32_t ar9280_2_0_fast_clock_vals_5g40[] = { 0x000004d0, 0x00000318, 0x00001fa0, 0x08980898, 0x148ec057, 0x00008980, 0x02020200, 0x01000f0f, 0x0b020001, 0x00000f0f, 0x03721821, 0x00001130, 0x00000016 }; #endif static const struct athn_ini ar9280_2_0_ini = { nitems(ar9280_2_0_regs), ar9280_2_0_regs, ar9280_2_0_vals_5g20, #ifndef IEEE80211_NO_HT ar9280_2_0_vals_5g40, ar9280_2_0_vals_2g40, #endif ar9280_2_0_vals_2g20, nitems(ar9280_2_0_cm_regs), ar9280_2_0_cm_regs, ar9280_2_0_cm_vals, nitems(ar9280_2_0_fast_clock_regs), ar9280_2_0_fast_clock_regs, ar9280_2_0_fast_clock_vals_5g20, #ifndef IEEE80211_NO_HT ar9280_2_0_fast_clock_vals_5g40 #endif }; /* * AR9280 2.0 Tx gains. */ static const uint16_t ar9280_2_0_tx_gain_regs[] = { P(0x0a274), P(0x0a27c), P(0x0a300), P(0x0a304), P(0x0a308), P(0x0a30c), P(0x0a310), P(0x0a314), P(0x0a318), P(0x0a31c), P(0x0a320), P(0x0a324), P(0x0a328), P(0x0a32c), P(0x0a330), P(0x0a334), P(0x0a338), P(0x0a33c), P(0x0a340), P(0x0a344), P(0x0a348), P(0x0a34c), P(0x0a350), P(0x0a354), P(0x0a3ec), P(0x07814), P(0x07838), P(0x0781c), P(0x07840), P(0x07820), P(0x07844) }; static const uint32_t ar9280_2_0_tx_gain_vals_5g[] = { 0x0a19c652, 0x050701ce, 0x00000000, 0x00003002, 0x00006004, 0x0000a006, 0x0000e012, 0x00011014, 0x0001504a, 0x0001904c, 0x0001c04e, 0x00020092, 0x0002410a, 0x0002710c, 0x0002b18b, 0x0002e1cc, 0x000321ec, 0x000321ec, 0x000321ec, 0x000321ec, 0x000321ec, 0x000321ec, 0x000321ec, 0x000321ec, 0x00f70081, 0x0019beff, 0x0019beff, 0x00392000, 0x00392000, 0x92592480, 0x92592480 }; static const uint32_t ar9280_2_0_tx_gain_vals_2g[] = { 0x0a1aa652, 0x050701ce, 0x00000000, 0x00003002, 0x00008009, 0x0000b00b, 0x0000e012, 0x00012048, 0x0001604a, 0x0001a211, 0x0001e213, 0x0002121b, 0x00024412, 0x00028414, 0x0002b44a, 0x00030649, 0x0003364b, 0x00038a49, 0x0003be48, 0x0003ee4a, 0x00042e88, 0x00046e8a, 0x00049ec9, 0x0004bf42, 0x00f70081, 0x0019beff, 0x0019beff, 0x00392000, 0x00392000, 0x92592480, 0x92592480 }; static const struct athn_gain ar9280_2_0_tx_gain = { nitems(ar9280_2_0_tx_gain_regs), ar9280_2_0_tx_gain_regs, ar9280_2_0_tx_gain_vals_5g, ar9280_2_0_tx_gain_vals_2g }; static const uint32_t ar9280_2_0_tx_gain_high_power_vals_5g[] = { 0x0a19e652, 0x050739ce, 0x00000000, 0x00003002, 0x00006004, 0x0000a006, 0x0000e012, 0x00011014, 0x0001504a, 0x0001904c, 0x0001c04e, 0x00021092, 0x0002510a, 0x0002910c, 0x0002c18b, 0x0002f1cc, 0x000321eb, 0x000341ec, 0x000341ec, 0x000341ec, 0x000341ec, 0x000341ec, 0x000341ec, 0x000341ec, 0x00f70081, 0x00198eff, 0x00198eff, 0x00172000, 0x00172000, 0xf258a480, 0xf258a480 }; static const uint32_t ar9280_2_0_tx_gain_high_power_vals_2g[] = { 0x0a1aa652, 0x050739ce, 0x00000000, 0x00004002, 0x00007008, 0x0000c010, 0x00010012, 0x00013014, 0x0001820a, 0x0001b211, 0x0001e213, 0x00022411, 0x00025413, 0x00029811, 0x0002c813, 0x00030a14, 0x00035a50, 0x00039c4c, 0x0003de8a, 0x00042e92, 0x00046ed2, 0x0004bed5, 0x0004ff54, 0x00055fd5, 0x00f70081, 0x00198eff, 0x00198eff, 0x00172000, 0x00172000, 0xf258a480, 0xf258a480 }; static const struct athn_gain ar9280_2_0_tx_gain_high_power = { nitems(ar9280_2_0_tx_gain_regs), ar9280_2_0_tx_gain_regs, ar9280_2_0_tx_gain_high_power_vals_5g, ar9280_2_0_tx_gain_high_power_vals_2g }; /* * AR9280 2.0 Rx gains. */ static const uint16_t ar9280_2_0_rx_gain_regs[] = { P(0x09a00), P(0x09a04), P(0x09a08), P(0x09a0c), P(0x09a10), P(0x09a14), P(0x09a18), P(0x09a1c), P(0x09a20), P(0x09a24), P(0x09a28), P(0x09a2c), P(0x09a30), P(0x09a34), P(0x09a38), P(0x09a3c), P(0x09a40), P(0x09a44), P(0x09a48), P(0x09a4c), P(0x09a50), P(0x09a54), P(0x09a58), P(0x09a5c), P(0x09a60), P(0x09a64), P(0x09a68), P(0x09a6c), P(0x09a70), P(0x09a74), P(0x09a78), P(0x09a7c), P(0x09a80), P(0x09a84), P(0x09a88), P(0x09a8c), P(0x09a90), P(0x09a94), P(0x09a98), P(0x09a9c), P(0x09aa0), P(0x09aa4), P(0x09aa8), P(0x09aac), P(0x09ab0), P(0x09ab4), P(0x09ab8), P(0x09abc), P(0x09ac0), P(0x09ac4), P(0x09ac8), P(0x09acc), P(0x09ad0), P(0x09ad4), P(0x09ad8), P(0x09adc), P(0x09ae0), P(0x09ae4), P(0x09ae8), P(0x09aec), P(0x09af0), P(0x09af4), P(0x09af8), P(0x09afc), P(0x09b00), P(0x09b04), P(0x09b08), P(0x09b0c), P(0x09b10), P(0x09b14), P(0x09b18), P(0x09b1c), P(0x09b20), P(0x09b24), P(0x09b28), P(0x09b2c), P(0x09b30), P(0x09b34), P(0x09b38), P(0x09b3c), P(0x09b40), P(0x09b44), P(0x09b48), P(0x09b4c), P(0x09b50), P(0x09b54), P(0x09b58), P(0x09b5c), P(0x09b60), P(0x09b64), P(0x09b68), P(0x09b6c), P(0x09b70), P(0x09b74), P(0x09b78), P(0x09b7c), P(0x09b80), P(0x09b84), P(0x09b88), P(0x09b8c), P(0x09b90), P(0x09b94), P(0x09b98), P(0x09b9c), P(0x09ba0), P(0x09ba4), P(0x09ba8), P(0x09bac), P(0x09bb0), P(0x09bb4), P(0x09bb8), P(0x09bbc), P(0x09bc0), P(0x09bc4), P(0x09bc8), P(0x09bcc), P(0x09bd0), P(0x09bd4), P(0x09bd8), P(0x09bdc), P(0x09be0), P(0x09be4), P(0x09be8), P(0x09bec), P(0x09bf0), P(0x09bf4), P(0x09bf8), P(0x09bfc), P(0x09848), P(0x0a848) }; static const uint32_t ar9280_2_0_rx_gain_vals_5g[] = { 0x00008184, 0x00008188, 0x0000818c, 0x00008190, 0x00008194, 0x00008200, 0x00008204, 0x00008208, 0x0000820c, 0x00008210, 0x00008214, 0x00008280, 0x00008284, 0x00008288, 0x0000828c, 0x00008290, 0x00008300, 0x00008304, 0x00008308, 0x0000830c, 0x00008310, 0x00008314, 0x00008380, 0x00008384, 0x00008388, 0x0000838c, 0x00008390, 0x00008394, 0x0000a380, 0x0000a384, 0x0000a388, 0x0000a38c, 0x0000a390, 0x0000a394, 0x0000a780, 0x0000a784, 0x0000a788, 0x0000a78c, 0x0000a790, 0x0000a794, 0x0000ab84, 0x0000ab88, 0x0000ab8c, 0x0000ab90, 0x0000ab94, 0x0000af80, 0x0000af84, 0x0000af88, 0x0000af8c, 0x0000af90, 0x0000af94, 0x0000b380, 0x0000b384, 0x0000b388, 0x0000b38c, 0x0000b390, 0x0000b394, 0x0000b398, 0x0000b780, 0x0000b784, 0x0000b788, 0x0000b78c, 0x0000b790, 0x0000b794, 0x0000b798, 0x0000d784, 0x0000d788, 0x0000d78c, 0x0000d790, 0x0000f780, 0x0000f784, 0x0000f788, 0x0000f78c, 0x0000f790, 0x0000f794, 0x0000f7a4, 0x0000f7a8, 0x0000f7ac, 0x0000f7b0, 0x0000f7b4, 0x0000f7a1, 0x0000f7a5, 0x0000f7a9, 0x0000f7ad, 0x0000f7b1, 0x0000f7b5, 0x0000f7c5, 0x0000f7c9, 0x0000f7cd, 0x0000f7d1, 0x0000f7d5, 0x0000f7c2, 0x0000f7c6, 0x0000f7ca, 0x0000f7ce, 0x0000f7d2, 0x0000f7d6, 0x0000f7c3, 0x0000f7c7, 0x0000f7cb, 0x0000f7d3, 0x0000f7d7, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x00001066, 0x00001066 }; static const uint32_t ar9280_2_0_rx_gain_vals_2g[] = { 0x00008000, 0x00008000, 0x00008000, 0x00008000, 0x00008000, 0x00008000, 0x00008004, 0x00008008, 0x0000800c, 0x00008080, 0x00008084, 0x00008088, 0x0000808c, 0x00008100, 0x00008104, 0x00008108, 0x0000810c, 0x00008110, 0x00008114, 0x00008180, 0x00008184, 0x00008188, 0x0000818c, 0x00008190, 0x00008194, 0x000081a0, 0x0000820c, 0x000081a8, 0x00008284, 0x00008288, 0x00008224, 0x00008290, 0x00008300, 0x00008304, 0x00008308, 0x0000830c, 0x00008380, 0x00008384, 0x00008700, 0x00008704, 0x00008708, 0x0000870c, 0x00008780, 0x00008784, 0x00008b00, 0x00008b04, 0x00008b08, 0x00008b0c, 0x00008b80, 0x00008b84, 0x00008b88, 0x00008b8c, 0x00008b90, 0x00008f80, 0x00008f84, 0x00008f88, 0x00008f8c, 0x00008f90, 0x0000930c, 0x00009310, 0x00009384, 0x00009388, 0x00009324, 0x00009704, 0x000096a4, 0x000096a8, 0x00009710, 0x00009714, 0x00009720, 0x00009724, 0x00009728, 0x0000972c, 0x000097a0, 0x000097a4, 0x000097a8, 0x000097b0, 0x000097b4, 0x000097b8, 0x000097a5, 0x000097a9, 0x000097ad, 0x000097b1, 0x000097b5, 0x000097b9, 0x000097c5, 0x000097c9, 0x000097d1, 0x000097d5, 0x000097d9, 0x000097c6, 0x000097ca, 0x000097ce, 0x000097d2, 0x000097d6, 0x000097c3, 0x000097c7, 0x000097cb, 0x000097cf, 0x000097d7, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x00001063, 0x00001063 }; static const struct athn_gain ar9280_2_0_rx_gain = { nitems(ar9280_2_0_rx_gain_regs), ar9280_2_0_rx_gain_regs, ar9280_2_0_rx_gain_vals_5g, ar9280_2_0_rx_gain_vals_2g }; static const uint32_t ar9280_2_0_rx_gain_13db_backoff_vals_5g[] = { 0x00008184, 0x00008188, 0x0000818c, 0x00008190, 0x00008194, 0x00008200, 0x00008204, 0x00008208, 0x0000820c, 0x00008210, 0x00008214, 0x00008280, 0x00008284, 0x00008288, 0x0000828c, 0x00008290, 0x00008300, 0x00008304, 0x00008308, 0x0000830c, 0x00008310, 0x00008314, 0x00008380, 0x00008384, 0x00008388, 0x0000838c, 0x00008390, 0x00008394, 0x0000a380, 0x0000a384, 0x0000a388, 0x0000a38c, 0x0000a390, 0x0000a394, 0x0000a780, 0x0000a784, 0x0000a788, 0x0000a78c, 0x0000a790, 0x0000a794, 0x0000ab84, 0x0000ab88, 0x0000ab8c, 0x0000ab90, 0x0000ab94, 0x0000af80, 0x0000af84, 0x0000af88, 0x0000af8c, 0x0000af90, 0x0000af94, 0x0000b380, 0x0000b384, 0x0000b388, 0x0000b38c, 0x0000b390, 0x0000b394, 0x0000b398, 0x0000b780, 0x0000b784, 0x0000b788, 0x0000b78c, 0x0000b790, 0x0000b794, 0x0000b798, 0x0000d784, 0x0000d788, 0x0000d78c, 0x0000d790, 0x0000f780, 0x0000f784, 0x0000f788, 0x0000f78c, 0x0000f790, 0x0000f794, 0x0000f7a4, 0x0000f7a8, 0x0000f7ac, 0x0000f7b0, 0x0000f7b4, 0x0000f7a1, 0x0000f7a5, 0x0000f7a9, 0x0000f7ad, 0x0000f7b1, 0x0000f7b5, 0x0000f7c5, 0x0000f7c9, 0x0000f7cd, 0x0000f7d1, 0x0000f7d5, 0x0000f7c2, 0x0000f7c6, 0x0000f7ca, 0x0000f7ce, 0x0000f7d2, 0x0000f7d6, 0x0000f7c3, 0x0000f7c7, 0x0000f7cb, 0x0000f7d3, 0x0000f7d7, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x00001066, 0x00001066 }; static const uint32_t ar9280_2_0_rx_gain_13db_backoff_vals_2g[] = { 0x00000290, 0x00000300, 0x00000304, 0x00000308, 0x0000030c, 0x00008000, 0x00008004, 0x00008008, 0x0000800c, 0x00008080, 0x00008084, 0x00008088, 0x0000808c, 0x00008100, 0x00008104, 0x00008108, 0x0000810c, 0x00008110, 0x00008114, 0x00008180, 0x00008184, 0x00008188, 0x0000818c, 0x00008190, 0x00008194, 0x000081a0, 0x0000820c, 0x000081a8, 0x00008284, 0x00008288, 0x00008224, 0x00008290, 0x00008300, 0x00008304, 0x00008308, 0x0000830c, 0x00008380, 0x00008384, 0x00008700, 0x00008704, 0x00008708, 0x0000870c, 0x00008780, 0x00008784, 0x00008b00, 0x00008b04, 0x00008b08, 0x00008b0c, 0x00008b80, 0x00008b84, 0x00008b88, 0x00008b8c, 0x00008b90, 0x00008f80, 0x00008f84, 0x00008f88, 0x00008f8c, 0x00008f90, 0x00009310, 0x00009314, 0x00009320, 0x00009324, 0x00009328, 0x0000932c, 0x00009330, 0x00009334, 0x00009321, 0x00009325, 0x00009329, 0x0000932d, 0x00009331, 0x00009335, 0x00009322, 0x00009326, 0x0000932a, 0x0000932e, 0x00009332, 0x00009336, 0x00009323, 0x00009327, 0x0000932b, 0x0000932f, 0x00009333, 0x00009337, 0x00009343, 0x00009347, 0x0000934b, 0x0000934f, 0x00009353, 0x00009357, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000105a, 0x0000105a }; static const struct athn_gain ar9280_2_0_rx_gain_13db_backoff = { nitems(ar9280_2_0_rx_gain_regs), ar9280_2_0_rx_gain_regs, ar9280_2_0_rx_gain_13db_backoff_vals_5g, ar9280_2_0_rx_gain_13db_backoff_vals_2g }; static const uint32_t ar9280_2_0_rx_gain_23db_backoff_vals_5g[] = { 0x00008184, 0x00008188, 0x0000818c, 0x00008190, 0x00008194, 0x00008200, 0x00008204, 0x00008208, 0x0000820c, 0x00008210, 0x00008214, 0x00008280, 0x00008284, 0x00008288, 0x0000828c, 0x00008290, 0x00008300, 0x00008304, 0x00008308, 0x0000830c, 0x00008310, 0x00008314, 0x00008380, 0x00008384, 0x00008388, 0x0000838c, 0x00008390, 0x00008394, 0x0000a380, 0x0000a384, 0x0000a388, 0x0000a38c, 0x0000a390, 0x0000a394, 0x0000a780, 0x0000a784, 0x0000a788, 0x0000a78c, 0x0000a790, 0x0000a794, 0x0000ab84, 0x0000ab88, 0x0000ab8c, 0x0000ab90, 0x0000ab94, 0x0000af80, 0x0000af84, 0x0000af88, 0x0000af8c, 0x0000af90, 0x0000af94, 0x0000b380, 0x0000b384, 0x0000b388, 0x0000b38c, 0x0000b390, 0x0000b394, 0x0000b398, 0x0000b780, 0x0000b784, 0x0000b788, 0x0000b78c, 0x0000b790, 0x0000b794, 0x0000b798, 0x0000d784, 0x0000d788, 0x0000d78c, 0x0000d790, 0x0000f780, 0x0000f784, 0x0000f788, 0x0000f78c, 0x0000f790, 0x0000f794, 0x0000f7a4, 0x0000f7a8, 0x0000f7ac, 0x0000f7b0, 0x0000f7b4, 0x0000f7a1, 0x0000f7a5, 0x0000f7a9, 0x0000f7ad, 0x0000f7b1, 0x0000f7b5, 0x0000f7c5, 0x0000f7c9, 0x0000f7cd, 0x0000f7d1, 0x0000f7d5, 0x0000f7c2, 0x0000f7c6, 0x0000f7ca, 0x0000f7ce, 0x0000f7d2, 0x0000f7d6, 0x0000f7c3, 0x0000f7c7, 0x0000f7cb, 0x0000f7d3, 0x0000f7d7, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x00001066, 0x00001066 }; static const uint32_t ar9280_2_0_rx_gain_23db_backoff_vals_2g[] = { 0x00000290, 0x00000300, 0x00000304, 0x00000308, 0x0000030c, 0x00008000, 0x00008004, 0x00008008, 0x0000800c, 0x00008080, 0x00008084, 0x00008088, 0x0000808c, 0x00008100, 0x00008104, 0x00008108, 0x0000810c, 0x00008110, 0x00008114, 0x00008180, 0x00008184, 0x00008188, 0x0000818c, 0x00008190, 0x00008194, 0x000081a0, 0x0000820c, 0x000081a8, 0x00008284, 0x00008288, 0x00008224, 0x00008290, 0x00008300, 0x00008304, 0x00008308, 0x0000830c, 0x00008380, 0x00008384, 0x00008700, 0x00008704, 0x00008708, 0x0000870c, 0x00008780, 0x00008784, 0x00008b00, 0x00008b04, 0x00008b08, 0x00008b0c, 0x00008b10, 0x00008b80, 0x00008b84, 0x00008b88, 0x00008b8c, 0x00008b90, 0x00008b94, 0x00008b98, 0x00008ba4, 0x00008ba8, 0x00008bac, 0x00008bb0, 0x00008bb4, 0x00008ba1, 0x00008ba5, 0x00008ba9, 0x00008bad, 0x00008bb1, 0x00008bb5, 0x00008ba2, 0x00008ba6, 0x00008baa, 0x00008bae, 0x00008bb2, 0x00008bb6, 0x00008ba3, 0x00008ba7, 0x00008bab, 0x00008baf, 0x00008bb3, 0x00008bb7, 0x00008bc3, 0x00008bc7, 0x00008bcb, 0x00008bcf, 0x00008bd3, 0x00008bd7, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00001055, 0x00001055 }; static const struct athn_gain ar9280_2_0_rx_gain_23db_backoff = { nitems(ar9280_2_0_rx_gain_regs), ar9280_2_0_rx_gain_regs, ar9280_2_0_rx_gain_23db_backoff_vals_5g, ar9280_2_0_rx_gain_23db_backoff_vals_2g }; /* * Serializer/Deserializer programming. */ static const uint32_t ar9280_2_0_serdes_regs[] = { AR_PCIE_SERDES, AR_PCIE_SERDES, AR_PCIE_SERDES, AR_PCIE_SERDES, AR_PCIE_SERDES, AR_PCIE_SERDES, AR_PCIE_SERDES, AR_PCIE_SERDES, AR_PCIE_SERDES, AR_PCIE_SERDES2, }; static const uint32_t ar9280_2_0_serdes_vals[] = { 0x9248fd00, 0x24924924, 0xa8000019, 0x13160820, 0xe5980560, #ifdef ATHN_PCIE_CLKREQ 0xc01dcffc, #else 0xc01dcffd, #endif 0x1aaabe41, 0xbe105554, 0x00043007, 0x00000000 }; static const struct athn_serdes ar9280_2_0_serdes = { nitems(ar9280_2_0_serdes_vals), ar9280_2_0_serdes_regs, ar9280_2_0_serdes_vals };