phy_n.h 60 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. #ifndef B43_NPHY_H_
  3. #define B43_NPHY_H_
  4. #include "phy_common.h"
  5. #include "ppr.h"
  6. /* N-PHY registers. */
  7. #define B43_NPHY_BBCFG B43_PHY_N(0x001) /* BB config */
  8. #define B43_NPHY_BBCFG_RSTCCA 0x4000 /* Reset CCA */
  9. #define B43_NPHY_BBCFG_RSTRX 0x8000 /* Reset RX */
  10. #define B43_NPHY_CHANNEL B43_PHY_N(0x005) /* Channel */
  11. #define B43_NPHY_TXERR B43_PHY_N(0x007) /* TX error */
  12. #define B43_NPHY_BANDCTL B43_PHY_N(0x009) /* Band control */
  13. #define B43_NPHY_BANDCTL_5GHZ 0x0001 /* Use the 5GHz band */
  14. #define B43_NPHY_4WI_ADDR B43_PHY_N(0x00B) /* Four-wire bus address */
  15. #define B43_NPHY_4WI_DATAHI B43_PHY_N(0x00C) /* Four-wire bus data high */
  16. #define B43_NPHY_4WI_DATALO B43_PHY_N(0x00D) /* Four-wire bus data low */
  17. #define B43_NPHY_BIST_STAT0 B43_PHY_N(0x00E) /* Built-in self test status 0 */
  18. #define B43_NPHY_BIST_STAT1 B43_PHY_N(0x00F) /* Built-in self test status 1 */
  19. #define B43_NPHY_C1_DESPWR B43_PHY_N(0x018) /* Core 1 desired power */
  20. #define B43_NPHY_C1_CCK_DESPWR B43_PHY_N(0x019) /* Core 1 CCK desired power */
  21. #define B43_NPHY_C1_BCLIPBKOFF B43_PHY_N(0x01A) /* Core 1 barely clip backoff */
  22. #define B43_NPHY_C1_CCK_BCLIPBKOFF B43_PHY_N(0x01B) /* Core 1 CCK barely clip backoff */
  23. #define B43_NPHY_C1_CGAINI B43_PHY_N(0x01C) /* Core 1 compute gain info */
  24. #define B43_NPHY_C1_CGAINI_GAINBKOFF 0x001F /* Gain backoff */
  25. #define B43_NPHY_C1_CGAINI_GAINBKOFF_SHIFT 0
  26. #define B43_NPHY_C1_CGAINI_CLIPGBKOFF 0x03E0 /* Clip gain backoff */
  27. #define B43_NPHY_C1_CGAINI_CLIPGBKOFF_SHIFT 5
  28. #define B43_NPHY_C1_CGAINI_GAINSTEP 0x1C00 /* Gain step */
  29. #define B43_NPHY_C1_CGAINI_GAINSTEP_SHIFT 10
  30. #define B43_NPHY_C1_CGAINI_CL2DETECT 0x2000 /* Clip 2 detect mask */
  31. #define B43_NPHY_C1_CCK_CGAINI B43_PHY_N(0x01D) /* Core 1 CCK compute gain info */
  32. #define B43_NPHY_C1_CCK_CGAINI_GAINBKOFF 0x001F /* Gain backoff */
  33. #define B43_NPHY_C1_CCK_CGAINI_CLIPGBKOFF 0x01E0 /* CCK barely clip gain backoff */
  34. #define B43_NPHY_C1_MINMAX_GAIN B43_PHY_N(0x01E) /* Core 1 min/max gain */
  35. #define B43_NPHY_C1_MINGAIN 0x00FF /* Minimum gain */
  36. #define B43_NPHY_C1_MINGAIN_SHIFT 0
  37. #define B43_NPHY_C1_MAXGAIN 0xFF00 /* Maximum gain */
  38. #define B43_NPHY_C1_MAXGAIN_SHIFT 8
  39. #define B43_NPHY_C1_CCK_MINMAX_GAIN B43_PHY_N(0x01F) /* Core 1 CCK min/max gain */
  40. #define B43_NPHY_C1_CCK_MINGAIN 0x00FF /* Minimum gain */
  41. #define B43_NPHY_C1_CCK_MINGAIN_SHIFT 0
  42. #define B43_NPHY_C1_CCK_MAXGAIN 0xFF00 /* Maximum gain */
  43. #define B43_NPHY_C1_CCK_MAXGAIN_SHIFT 8
  44. #define B43_NPHY_C1_INITGAIN B43_PHY_N(0x020) /* Core 1 initial gain code */
  45. #define B43_NPHY_C1_INITGAIN_EXTLNA 0x0001 /* External LNA index */
  46. #define B43_NPHY_C1_INITGAIN_LNA 0x0006 /* LNA index */
  47. #define B43_NPHY_C1_INITGAIN_LNAIDX_SHIFT 1
  48. #define B43_NPHY_C1_INITGAIN_HPVGA1 0x0078 /* HPVGA1 index */
  49. #define B43_NPHY_C1_INITGAIN_HPVGA1_SHIFT 3
  50. #define B43_NPHY_C1_INITGAIN_HPVGA2 0x0F80 /* HPVGA2 index */
  51. #define B43_NPHY_C1_INITGAIN_HPVGA2_SHIFT 7
  52. #define B43_NPHY_C1_INITGAIN_TRRX 0x1000 /* TR RX index */
  53. #define B43_NPHY_C1_INITGAIN_TRTX 0x2000 /* TR TX index */
  54. #define B43_NPHY_REV3_C1_INITGAIN_A B43_PHY_N(0x020)
  55. #define B43_NPHY_C1_CLIP1_HIGAIN B43_PHY_N(0x021) /* Core 1 clip1 high gain code */
  56. #define B43_NPHY_REV3_C1_INITGAIN_B B43_PHY_N(0x021)
  57. #define B43_NPHY_C1_CLIP1_MEDGAIN B43_PHY_N(0x022) /* Core 1 clip1 medium gain code */
  58. #define B43_NPHY_REV3_C1_CLIP_HIGAIN_A B43_PHY_N(0x022)
  59. #define B43_NPHY_C1_CLIP1_LOGAIN B43_PHY_N(0x023) /* Core 1 clip1 low gain code */
  60. #define B43_NPHY_REV3_C1_CLIP_HIGAIN_B B43_PHY_N(0x023)
  61. #define B43_NPHY_C1_CLIP2_GAIN B43_PHY_N(0x024) /* Core 1 clip2 gain code */
  62. #define B43_NPHY_REV3_C1_CLIP_MEDGAIN_A B43_PHY_N(0x024)
  63. #define B43_NPHY_C1_FILTERGAIN B43_PHY_N(0x025) /* Core 1 filter gain */
  64. #define B43_NPHY_C1_LPF_QHPF_BW B43_PHY_N(0x026) /* Core 1 LPF Q HP F bandwidth */
  65. #define B43_NPHY_C1_CLIPWBTHRES B43_PHY_N(0x027) /* Core 1 clip wideband threshold */
  66. #define B43_NPHY_C1_CLIPWBTHRES_CLIP2 0x003F /* Clip 2 */
  67. #define B43_NPHY_C1_CLIPWBTHRES_CLIP2_SHIFT 0
  68. #define B43_NPHY_C1_CLIPWBTHRES_CLIP1 0x0FC0 /* Clip 1 */
  69. #define B43_NPHY_C1_CLIPWBTHRES_CLIP1_SHIFT 6
  70. #define B43_NPHY_C1_W1THRES B43_PHY_N(0x028) /* Core 1 W1 threshold */
  71. #define B43_NPHY_C1_EDTHRES B43_PHY_N(0x029) /* Core 1 ED threshold */
  72. #define B43_NPHY_C1_SMSIGTHRES B43_PHY_N(0x02A) /* Core 1 small sig threshold */
  73. #define B43_NPHY_C1_NBCLIPTHRES B43_PHY_N(0x02B) /* Core 1 NB clip threshold */
  74. #define B43_NPHY_C1_CLIP1THRES B43_PHY_N(0x02C) /* Core 1 clip1 threshold */
  75. #define B43_NPHY_C1_CLIP2THRES B43_PHY_N(0x02D) /* Core 1 clip2 threshold */
  76. #define B43_NPHY_C2_DESPWR B43_PHY_N(0x02E) /* Core 2 desired power */
  77. #define B43_NPHY_C2_CCK_DESPWR B43_PHY_N(0x02F) /* Core 2 CCK desired power */
  78. #define B43_NPHY_C2_BCLIPBKOFF B43_PHY_N(0x030) /* Core 2 barely clip backoff */
  79. #define B43_NPHY_C2_CCK_BCLIPBKOFF B43_PHY_N(0x031) /* Core 2 CCK barely clip backoff */
  80. #define B43_NPHY_C2_CGAINI B43_PHY_N(0x032) /* Core 2 compute gain info */
  81. #define B43_NPHY_C2_CGAINI_GAINBKOFF 0x001F /* Gain backoff */
  82. #define B43_NPHY_C2_CGAINI_GAINBKOFF_SHIFT 0
  83. #define B43_NPHY_C2_CGAINI_CLIPGBKOFF 0x03E0 /* Clip gain backoff */
  84. #define B43_NPHY_C2_CGAINI_CLIPGBKOFF_SHIFT 5
  85. #define B43_NPHY_C2_CGAINI_GAINSTEP 0x1C00 /* Gain step */
  86. #define B43_NPHY_C2_CGAINI_GAINSTEP_SHIFT 10
  87. #define B43_NPHY_C2_CGAINI_CL2DETECT 0x2000 /* Clip 2 detect mask */
  88. #define B43_NPHY_C2_CCK_CGAINI B43_PHY_N(0x033) /* Core 2 CCK compute gain info */
  89. #define B43_NPHY_C2_CCK_CGAINI_GAINBKOFF 0x001F /* Gain backoff */
  90. #define B43_NPHY_C2_CCK_CGAINI_CLIPGBKOFF 0x01E0 /* CCK barely clip gain backoff */
  91. #define B43_NPHY_C2_MINMAX_GAIN B43_PHY_N(0x034) /* Core 2 min/max gain */
  92. #define B43_NPHY_C2_MINGAIN 0x00FF /* Minimum gain */
  93. #define B43_NPHY_C2_MINGAIN_SHIFT 0
  94. #define B43_NPHY_C2_MAXGAIN 0xFF00 /* Maximum gain */
  95. #define B43_NPHY_C2_MAXGAIN_SHIFT 8
  96. #define B43_NPHY_C2_CCK_MINMAX_GAIN B43_PHY_N(0x035) /* Core 2 CCK min/max gain */
  97. #define B43_NPHY_C2_CCK_MINGAIN 0x00FF /* Minimum gain */
  98. #define B43_NPHY_C2_CCK_MINGAIN_SHIFT 0
  99. #define B43_NPHY_C2_CCK_MAXGAIN 0xFF00 /* Maximum gain */
  100. #define B43_NPHY_C2_CCK_MAXGAIN_SHIFT 8
  101. #define B43_NPHY_C2_INITGAIN B43_PHY_N(0x036) /* Core 2 initial gain code */
  102. #define B43_NPHY_C2_INITGAIN_EXTLNA 0x0001 /* External LNA index */
  103. #define B43_NPHY_C2_INITGAIN_LNA 0x0006 /* LNA index */
  104. #define B43_NPHY_C2_INITGAIN_LNAIDX_SHIFT 1
  105. #define B43_NPHY_C2_INITGAIN_HPVGA1 0x0078 /* HPVGA1 index */
  106. #define B43_NPHY_C2_INITGAIN_HPVGA1_SHIFT 3
  107. #define B43_NPHY_C2_INITGAIN_HPVGA2 0x0F80 /* HPVGA2 index */
  108. #define B43_NPHY_C2_INITGAIN_HPVGA2_SHIFT 7
  109. #define B43_NPHY_C2_INITGAIN_TRRX 0x1000 /* TR RX index */
  110. #define B43_NPHY_C2_INITGAIN_TRTX 0x2000 /* TR TX index */
  111. #define B43_NPHY_REV3_C1_CLIP_MEDGAIN_B B43_PHY_N(0x036)
  112. #define B43_NPHY_C2_CLIP1_HIGAIN B43_PHY_N(0x037) /* Core 2 clip1 high gain code */
  113. #define B43_NPHY_REV3_C1_CLIP_LOGAIN_A B43_PHY_N(0x037)
  114. #define B43_NPHY_C2_CLIP1_MEDGAIN B43_PHY_N(0x038) /* Core 2 clip1 medium gain code */
  115. #define B43_NPHY_REV3_C1_CLIP_LOGAIN_B B43_PHY_N(0x038)
  116. #define B43_NPHY_C2_CLIP1_LOGAIN B43_PHY_N(0x039) /* Core 2 clip1 low gain code */
  117. #define B43_NPHY_REV3_C1_CLIP2_GAIN_A B43_PHY_N(0x039)
  118. #define B43_NPHY_C2_CLIP2_GAIN B43_PHY_N(0x03A) /* Core 2 clip2 gain code */
  119. #define B43_NPHY_REV3_C1_CLIP2_GAIN_B B43_PHY_N(0x03A)
  120. #define B43_NPHY_C2_FILTERGAIN B43_PHY_N(0x03B) /* Core 2 filter gain */
  121. #define B43_NPHY_C2_LPF_QHPF_BW B43_PHY_N(0x03C) /* Core 2 LPF Q HP F bandwidth */
  122. #define B43_NPHY_C2_CLIPWBTHRES B43_PHY_N(0x03D) /* Core 2 clip wideband threshold */
  123. #define B43_NPHY_C2_CLIPWBTHRES_CLIP2 0x003F /* Clip 2 */
  124. #define B43_NPHY_C2_CLIPWBTHRES_CLIP2_SHIFT 0
  125. #define B43_NPHY_C2_CLIPWBTHRES_CLIP1 0x0FC0 /* Clip 1 */
  126. #define B43_NPHY_C2_CLIPWBTHRES_CLIP1_SHIFT 6
  127. #define B43_NPHY_C2_W1THRES B43_PHY_N(0x03E) /* Core 2 W1 threshold */
  128. #define B43_NPHY_C2_EDTHRES B43_PHY_N(0x03F) /* Core 2 ED threshold */
  129. #define B43_NPHY_C2_SMSIGTHRES B43_PHY_N(0x040) /* Core 2 small sig threshold */
  130. #define B43_NPHY_C2_NBCLIPTHRES B43_PHY_N(0x041) /* Core 2 NB clip threshold */
  131. #define B43_NPHY_C2_CLIP1THRES B43_PHY_N(0x042) /* Core 2 clip1 threshold */
  132. #define B43_NPHY_C2_CLIP2THRES B43_PHY_N(0x043) /* Core 2 clip2 threshold */
  133. #define B43_NPHY_CRS_THRES1 B43_PHY_N(0x044) /* CRS threshold 1 */
  134. #define B43_NPHY_CRS_THRES2 B43_PHY_N(0x045) /* CRS threshold 2 */
  135. #define B43_NPHY_CRS_THRES3 B43_PHY_N(0x046) /* CRS threshold 3 */
  136. #define B43_NPHY_CRSCTL B43_PHY_N(0x047) /* CRS control */
  137. #define B43_NPHY_DCFADDR B43_PHY_N(0x048) /* DC filter address */
  138. #define B43_NPHY_RXF20_NUM0 B43_PHY_N(0x049) /* RX filter 20 numerator 0 */
  139. #define B43_NPHY_RXF20_NUM1 B43_PHY_N(0x04A) /* RX filter 20 numerator 1 */
  140. #define B43_NPHY_RXF20_NUM2 B43_PHY_N(0x04B) /* RX filter 20 numerator 2 */
  141. #define B43_NPHY_RXF20_DENOM0 B43_PHY_N(0x04C) /* RX filter 20 denominator 0 */
  142. #define B43_NPHY_RXF20_DENOM1 B43_PHY_N(0x04D) /* RX filter 20 denominator 1 */
  143. #define B43_NPHY_RXF20_NUM10 B43_PHY_N(0x04E) /* RX filter 20 numerator 10 */
  144. #define B43_NPHY_RXF20_NUM11 B43_PHY_N(0x04F) /* RX filter 20 numerator 11 */
  145. #define B43_NPHY_RXF20_NUM12 B43_PHY_N(0x050) /* RX filter 20 numerator 12 */
  146. #define B43_NPHY_RXF20_DENOM10 B43_PHY_N(0x051) /* RX filter 20 denominator 10 */
  147. #define B43_NPHY_RXF20_DENOM11 B43_PHY_N(0x052) /* RX filter 20 denominator 11 */
  148. #define B43_NPHY_RXF40_NUM0 B43_PHY_N(0x053) /* RX filter 40 numerator 0 */
  149. #define B43_NPHY_RXF40_NUM1 B43_PHY_N(0x054) /* RX filter 40 numerator 1 */
  150. #define B43_NPHY_RXF40_NUM2 B43_PHY_N(0x055) /* RX filter 40 numerator 2 */
  151. #define B43_NPHY_RXF40_DENOM0 B43_PHY_N(0x056) /* RX filter 40 denominator 0 */
  152. #define B43_NPHY_RXF40_DENOM1 B43_PHY_N(0x057) /* RX filter 40 denominator 1 */
  153. #define B43_NPHY_RXF40_NUM10 B43_PHY_N(0x058) /* RX filter 40 numerator 10 */
  154. #define B43_NPHY_RXF40_NUM11 B43_PHY_N(0x059) /* RX filter 40 numerator 11 */
  155. #define B43_NPHY_RXF40_NUM12 B43_PHY_N(0x05A) /* RX filter 40 numerator 12 */
  156. #define B43_NPHY_RXF40_DENOM10 B43_PHY_N(0x05B) /* RX filter 40 denominator 10 */
  157. #define B43_NPHY_RXF40_DENOM11 B43_PHY_N(0x05C) /* RX filter 40 denominator 11 */
  158. #define B43_NPHY_PPROC_RSTLEN B43_PHY_N(0x060) /* Packet processing reset length */
  159. #define B43_NPHY_INITCARR_DLEN B43_PHY_N(0x061) /* Initial carrier detection length */
  160. #define B43_NPHY_CLIP1CARR_DLEN B43_PHY_N(0x062) /* Clip1 carrier detection length */
  161. #define B43_NPHY_CLIP2CARR_DLEN B43_PHY_N(0x063) /* Clip2 carrier detection length */
  162. #define B43_NPHY_INITGAIN_SLEN B43_PHY_N(0x064) /* Initial gain settle length */
  163. #define B43_NPHY_CLIP1GAIN_SLEN B43_PHY_N(0x065) /* Clip1 gain settle length */
  164. #define B43_NPHY_CLIP2GAIN_SLEN B43_PHY_N(0x066) /* Clip2 gain settle length */
  165. #define B43_NPHY_PACKGAIN_SLEN B43_PHY_N(0x067) /* Packet gain settle length */
  166. #define B43_NPHY_CARRSRC_TLEN B43_PHY_N(0x068) /* Carrier search timeout length */
  167. #define B43_NPHY_TISRC_TLEN B43_PHY_N(0x069) /* Timing search timeout length */
  168. #define B43_NPHY_ENDROP_TLEN B43_PHY_N(0x06A) /* Energy drop timeout length */
  169. #define B43_NPHY_CLIP1_NBDWELL_LEN B43_PHY_N(0x06B) /* Clip1 NB dwell length */
  170. #define B43_NPHY_CLIP2_NBDWELL_LEN B43_PHY_N(0x06C) /* Clip2 NB dwell length */
  171. #define B43_NPHY_W1CLIP1_DWELL_LEN B43_PHY_N(0x06D) /* W1 clip1 dwell length */
  172. #define B43_NPHY_W1CLIP2_DWELL_LEN B43_PHY_N(0x06E) /* W1 clip2 dwell length */
  173. #define B43_NPHY_W2CLIP1_DWELL_LEN B43_PHY_N(0x06F) /* W2 clip1 dwell length */
  174. #define B43_NPHY_PLOAD_CSENSE_EXTLEN B43_PHY_N(0x070) /* Payload carrier sense extension length */
  175. #define B43_NPHY_EDROP_CSENSE_EXTLEN B43_PHY_N(0x071) /* Energy drop carrier sense extension length */
  176. #define B43_NPHY_TABLE_ADDR B43_PHY_N(0x072) /* Table address */
  177. #define B43_NPHY_TABLE_DATALO B43_PHY_N(0x073) /* Table data low */
  178. #define B43_NPHY_TABLE_DATAHI B43_PHY_N(0x074) /* Table data high */
  179. #define B43_NPHY_WWISE_LENIDX B43_PHY_N(0x075) /* WWiSE length index */
  180. #define B43_NPHY_TGNSYNC_LENIDX B43_PHY_N(0x076) /* TGNsync length index */
  181. #define B43_NPHY_TXMACIF_HOLDOFF B43_PHY_N(0x077) /* TX MAC IF Hold off */
  182. #define B43_NPHY_RFCTL_CMD B43_PHY_N(0x078) /* RF control (command) */
  183. #define B43_NPHY_RFCTL_CMD_START 0x0001 /* Start sequence */
  184. #define B43_NPHY_RFCTL_CMD_RXTX 0x0002 /* RX/TX */
  185. #define B43_NPHY_RFCTL_CMD_CORESEL 0x0038 /* Core select */
  186. #define B43_NPHY_RFCTL_CMD_CORESEL_SHIFT 3
  187. #define B43_NPHY_RFCTL_CMD_PORFORCE 0x0040 /* POR force */
  188. #define B43_NPHY_RFCTL_CMD_OEPORFORCE 0x0080 /* OE POR force */
  189. #define B43_NPHY_RFCTL_CMD_RXEN 0x0100 /* RX enable */
  190. #define B43_NPHY_RFCTL_CMD_TXEN 0x0200 /* TX enable */
  191. #define B43_NPHY_RFCTL_CMD_CHIP0PU 0x0400 /* Chip0 PU */
  192. #define B43_NPHY_RFCTL_CMD_EN 0x0800 /* Radio enabled */
  193. #define B43_NPHY_RFCTL_CMD_SEQENCORE 0xF000 /* Seq en core */
  194. #define B43_NPHY_RFCTL_CMD_SEQENCORE_SHIFT 12
  195. #define B43_NPHY_RFCTL_RSSIO1 B43_PHY_N(0x07A) /* RF control (RSSI others 1) */
  196. #define B43_NPHY_RFCTL_RSSIO1_RXPD 0x0001 /* RX PD */
  197. #define B43_NPHY_RFCTL_RSSIO1_TXPD 0x0002 /* TX PD */
  198. #define B43_NPHY_RFCTL_RSSIO1_PAPD 0x0004 /* PA PD */
  199. #define B43_NPHY_RFCTL_RSSIO1_RSSICTL 0x0030 /* RSSI control */
  200. #define B43_NPHY_RFCTL_RSSIO1_LPFBW 0x00C0 /* LPF bandwidth */
  201. #define B43_NPHY_RFCTL_RSSIO1_HPFBWHI 0x0100 /* HPF bandwidth high */
  202. #define B43_NPHY_RFCTL_RSSIO1_HIQDISCO 0x0200 /* HIQ dis core */
  203. #define B43_NPHY_RFCTL_RXG1 B43_PHY_N(0x07B) /* RF control (RX gain 1) */
  204. #define B43_NPHY_RFCTL_TXG1 B43_PHY_N(0x07C) /* RF control (TX gain 1) */
  205. #define B43_NPHY_RFCTL_RSSIO2 B43_PHY_N(0x07D) /* RF control (RSSI others 2) */
  206. #define B43_NPHY_RFCTL_RSSIO2_RXPD 0x0001 /* RX PD */
  207. #define B43_NPHY_RFCTL_RSSIO2_TXPD 0x0002 /* TX PD */
  208. #define B43_NPHY_RFCTL_RSSIO2_PAPD 0x0004 /* PA PD */
  209. #define B43_NPHY_RFCTL_RSSIO2_RSSICTL 0x0030 /* RSSI control */
  210. #define B43_NPHY_RFCTL_RSSIO2_LPFBW 0x00C0 /* LPF bandwidth */
  211. #define B43_NPHY_RFCTL_RSSIO2_HPFBWHI 0x0100 /* HPF bandwidth high */
  212. #define B43_NPHY_RFCTL_RSSIO2_HIQDISCO 0x0200 /* HIQ dis core */
  213. #define B43_NPHY_RFCTL_RXG2 B43_PHY_N(0x07E) /* RF control (RX gain 2) */
  214. #define B43_NPHY_RFCTL_TXG2 B43_PHY_N(0x07F) /* RF control (TX gain 2) */
  215. #define B43_NPHY_RFCTL_RSSIO3 B43_PHY_N(0x080) /* RF control (RSSI others 3) */
  216. #define B43_NPHY_RFCTL_RSSIO3_RXPD 0x0001 /* RX PD */
  217. #define B43_NPHY_RFCTL_RSSIO3_TXPD 0x0002 /* TX PD */
  218. #define B43_NPHY_RFCTL_RSSIO3_PAPD 0x0004 /* PA PD */
  219. #define B43_NPHY_RFCTL_RSSIO3_RSSICTL 0x0030 /* RSSI control */
  220. #define B43_NPHY_RFCTL_RSSIO3_LPFBW 0x00C0 /* LPF bandwidth */
  221. #define B43_NPHY_RFCTL_RSSIO3_HPFBWHI 0x0100 /* HPF bandwidth high */
  222. #define B43_NPHY_RFCTL_RSSIO3_HIQDISCO 0x0200 /* HIQ dis core */
  223. #define B43_NPHY_RFCTL_RXG3 B43_PHY_N(0x081) /* RF control (RX gain 3) */
  224. #define B43_NPHY_RFCTL_TXG3 B43_PHY_N(0x082) /* RF control (TX gain 3) */
  225. #define B43_NPHY_RFCTL_RSSIO4 B43_PHY_N(0x083) /* RF control (RSSI others 4) */
  226. #define B43_NPHY_RFCTL_RSSIO4_RXPD 0x0001 /* RX PD */
  227. #define B43_NPHY_RFCTL_RSSIO4_TXPD 0x0002 /* TX PD */
  228. #define B43_NPHY_RFCTL_RSSIO4_PAPD 0x0004 /* PA PD */
  229. #define B43_NPHY_RFCTL_RSSIO4_RSSICTL 0x0030 /* RSSI control */
  230. #define B43_NPHY_RFCTL_RSSIO4_LPFBW 0x00C0 /* LPF bandwidth */
  231. #define B43_NPHY_RFCTL_RSSIO4_HPFBWHI 0x0100 /* HPF bandwidth high */
  232. #define B43_NPHY_RFCTL_RSSIO4_HIQDISCO 0x0200 /* HIQ dis core */
  233. #define B43_NPHY_RFCTL_RXG4 B43_PHY_N(0x084) /* RF control (RX gain 4) */
  234. #define B43_NPHY_RFCTL_TXG4 B43_PHY_N(0x085) /* RF control (TX gain 4) */
  235. #define B43_NPHY_C1_TXIQ_COMP_OFF B43_PHY_N(0x087) /* Core 1 TX I/Q comp offset */
  236. #define B43_NPHY_C2_TXIQ_COMP_OFF B43_PHY_N(0x088) /* Core 2 TX I/Q comp offset */
  237. #define B43_NPHY_C1_TXCTL B43_PHY_N(0x08B) /* Core 1 TX control */
  238. #define B43_NPHY_C2_TXCTL B43_PHY_N(0x08C) /* Core 2 TX control */
  239. #define B43_NPHY_AFECTL_OVER1 B43_PHY_N(0x08F) /* AFE control override 1 */
  240. #define B43_NPHY_SCRAM_SIGCTL B43_PHY_N(0x090) /* Scram signal control */
  241. #define B43_NPHY_SCRAM_SIGCTL_INITST 0x007F /* Initial state value */
  242. #define B43_NPHY_SCRAM_SIGCTL_INITST_SHIFT 0
  243. #define B43_NPHY_SCRAM_SIGCTL_SCM 0x0080 /* Scram control mode */
  244. #define B43_NPHY_SCRAM_SIGCTL_SICE 0x0100 /* Scram index control enable */
  245. #define B43_NPHY_SCRAM_SIGCTL_START 0xFE00 /* Scram start bit */
  246. #define B43_NPHY_SCRAM_SIGCTL_START_SHIFT 9
  247. #define B43_NPHY_RFCTL_INTC1 B43_PHY_N(0x091) /* RF control (intc 1) */
  248. #define B43_NPHY_RFCTL_INTC2 B43_PHY_N(0x092) /* RF control (intc 2) */
  249. #define B43_NPHY_RFCTL_INTC3 B43_PHY_N(0x093) /* RF control (intc 3) */
  250. #define B43_NPHY_RFCTL_INTC4 B43_PHY_N(0x094) /* RF control (intc 4) */
  251. #define B43_NPHY_NRDTO_WWISE B43_PHY_N(0x095) /* # datatones WWiSE */
  252. #define B43_NPHY_NRDTO_TGNSYNC B43_PHY_N(0x096) /* # datatones TGNsync */
  253. #define B43_NPHY_SIGFMOD_WWISE B43_PHY_N(0x097) /* Signal field mod WWiSE */
  254. #define B43_NPHY_LEG_SIGFMOD_11N B43_PHY_N(0x098) /* Legacy signal field mod 11n */
  255. #define B43_NPHY_HT_SIGFMOD_11N B43_PHY_N(0x099) /* HT signal field mod 11n */
  256. #define B43_NPHY_C1_RXIQ_COMPA0 B43_PHY_N(0x09A) /* Core 1 RX I/Q comp A0 */
  257. #define B43_NPHY_C1_RXIQ_COMPB0 B43_PHY_N(0x09B) /* Core 1 RX I/Q comp B0 */
  258. #define B43_NPHY_C2_RXIQ_COMPA1 B43_PHY_N(0x09C) /* Core 2 RX I/Q comp A1 */
  259. #define B43_NPHY_C2_RXIQ_COMPB1 B43_PHY_N(0x09D) /* Core 2 RX I/Q comp B1 */
  260. #define B43_NPHY_RXCTL B43_PHY_N(0x0A0) /* RX control */
  261. #define B43_NPHY_RXCTL_BSELU20 0x0010 /* Band select upper 20 */
  262. #define B43_NPHY_RXCTL_RIFSEN 0x0080 /* RIFS enable */
  263. #define B43_NPHY_RFSEQMODE B43_PHY_N(0x0A1) /* RF seq mode */
  264. #define B43_NPHY_RFSEQMODE_CAOVER 0x0001 /* Core active override */
  265. #define B43_NPHY_RFSEQMODE_TROVER 0x0002 /* Trigger override */
  266. #define B43_NPHY_RFSEQCA B43_PHY_N(0x0A2) /* RF seq core active */
  267. #define B43_NPHY_RFSEQCA_TXEN 0x000F /* TX enable */
  268. #define B43_NPHY_RFSEQCA_TXEN_SHIFT 0
  269. #define B43_NPHY_RFSEQCA_RXEN 0x00F0 /* RX enable */
  270. #define B43_NPHY_RFSEQCA_RXEN_SHIFT 4
  271. #define B43_NPHY_RFSEQCA_TXDIS 0x0F00 /* TX disable */
  272. #define B43_NPHY_RFSEQCA_TXDIS_SHIFT 8
  273. #define B43_NPHY_RFSEQCA_RXDIS 0xF000 /* RX disable */
  274. #define B43_NPHY_RFSEQCA_RXDIS_SHIFT 12
  275. #define B43_NPHY_RFSEQTR B43_PHY_N(0x0A3) /* RF seq trigger */
  276. #define B43_NPHY_RFSEQTR_RX2TX 0x0001 /* RX2TX */
  277. #define B43_NPHY_RFSEQTR_TX2RX 0x0002 /* TX2RX */
  278. #define B43_NPHY_RFSEQTR_UPGH 0x0004 /* Update gain H */
  279. #define B43_NPHY_RFSEQTR_UPGL 0x0008 /* Update gain L */
  280. #define B43_NPHY_RFSEQTR_UPGU 0x0010 /* Update gain U */
  281. #define B43_NPHY_RFSEQTR_RST2RX 0x0020 /* Reset to RX */
  282. #define B43_NPHY_RFSEQST B43_PHY_N(0x0A4) /* RF seq status. Values same as trigger. */
  283. #define B43_NPHY_AFECTL_OVER B43_PHY_N(0x0A5) /* AFE control override */
  284. #define B43_NPHY_AFECTL_C1 B43_PHY_N(0x0A6) /* AFE control core 1 */
  285. #define B43_NPHY_AFECTL_C2 B43_PHY_N(0x0A7) /* AFE control core 2 */
  286. #define B43_NPHY_AFECTL_C3 B43_PHY_N(0x0A8) /* AFE control core 3 */
  287. #define B43_NPHY_AFECTL_C4 B43_PHY_N(0x0A9) /* AFE control core 4 */
  288. #define B43_NPHY_AFECTL_DACGAIN1 B43_PHY_N(0x0AA) /* AFE control DAC gain 1 */
  289. #define B43_NPHY_AFECTL_DACGAIN2 B43_PHY_N(0x0AB) /* AFE control DAC gain 2 */
  290. #define B43_NPHY_AFECTL_DACGAIN3 B43_PHY_N(0x0AC) /* AFE control DAC gain 3 */
  291. #define B43_NPHY_AFECTL_DACGAIN4 B43_PHY_N(0x0AD) /* AFE control DAC gain 4 */
  292. #define B43_NPHY_STR_ADDR1 B43_PHY_N(0x0AE) /* STR address 1 */
  293. #define B43_NPHY_STR_ADDR2 B43_PHY_N(0x0AF) /* STR address 2 */
  294. #define B43_NPHY_CLASSCTL B43_PHY_N(0x0B0) /* Classifier control */
  295. #define B43_NPHY_CLASSCTL_CCKEN 0x0001 /* CCK enable */
  296. #define B43_NPHY_CLASSCTL_OFDMEN 0x0002 /* OFDM enable */
  297. #define B43_NPHY_CLASSCTL_WAITEDEN 0x0004 /* Waited enable */
  298. #define B43_NPHY_IQFLIP B43_PHY_N(0x0B1) /* I/Q flip */
  299. #define B43_NPHY_IQFLIP_ADC1 0x0001 /* ADC1 */
  300. #define B43_NPHY_IQFLIP_ADC2 0x0010 /* ADC2 */
  301. #define B43_NPHY_SISO_SNR_THRES B43_PHY_N(0x0B2) /* SISO SNR threshold */
  302. #define B43_NPHY_SIGMA_N_MULT B43_PHY_N(0x0B3) /* Sigma N multiplier */
  303. #define B43_NPHY_TXMACDELAY B43_PHY_N(0x0B4) /* TX MAC delay */
  304. #define B43_NPHY_TXFRAMEDELAY B43_PHY_N(0x0B5) /* TX frame delay */
  305. #define B43_NPHY_MLPARM B43_PHY_N(0x0B6) /* ML parameters */
  306. #define B43_NPHY_MLCTL B43_PHY_N(0x0B7) /* ML control */
  307. #define B43_NPHY_WWISE_20NCYCDAT B43_PHY_N(0x0B8) /* WWiSE 20 N cyc data */
  308. #define B43_NPHY_WWISE_40NCYCDAT B43_PHY_N(0x0B9) /* WWiSE 40 N cyc data */
  309. #define B43_NPHY_TGNSYNC_20NCYCDAT B43_PHY_N(0x0BA) /* TGNsync 20 N cyc data */
  310. #define B43_NPHY_TGNSYNC_40NCYCDAT B43_PHY_N(0x0BB) /* TGNsync 40 N cyc data */
  311. #define B43_NPHY_INITSWIZP B43_PHY_N(0x0BC) /* Initial swizzle pattern */
  312. #define B43_NPHY_TXTAILCNT B43_PHY_N(0x0BD) /* TX tail count value */
  313. #define B43_NPHY_BPHY_CTL1 B43_PHY_N(0x0BE) /* B PHY control 1 */
  314. #define B43_NPHY_BPHY_CTL2 B43_PHY_N(0x0BF) /* B PHY control 2 */
  315. #define B43_NPHY_BPHY_CTL2_LUT 0x001F /* LUT index */
  316. #define B43_NPHY_BPHY_CTL2_LUT_SHIFT 0
  317. #define B43_NPHY_BPHY_CTL2_MACDEL 0x7FE0 /* MAC delay */
  318. #define B43_NPHY_BPHY_CTL2_MACDEL_SHIFT 5
  319. #define B43_NPHY_IQLOCAL_CMD B43_PHY_N(0x0C0) /* I/Q LO cal command */
  320. #define B43_NPHY_IQLOCAL_CMD_EN 0x8000
  321. #define B43_NPHY_IQLOCAL_CMDNNUM B43_PHY_N(0x0C1) /* I/Q LO cal command N num */
  322. #define B43_NPHY_IQLOCAL_CMDGCTL B43_PHY_N(0x0C2) /* I/Q LO cal command G control */
  323. #define B43_NPHY_SAMP_CMD B43_PHY_N(0x0C3) /* Sample command */
  324. #define B43_NPHY_SAMP_CMD_STOP 0x0002 /* Stop */
  325. #define B43_NPHY_SAMP_LOOPCNT B43_PHY_N(0x0C4) /* Sample loop count */
  326. #define B43_NPHY_SAMP_WAITCNT B43_PHY_N(0x0C5) /* Sample wait count */
  327. #define B43_NPHY_SAMP_DEPCNT B43_PHY_N(0x0C6) /* Sample depth count */
  328. #define B43_NPHY_SAMP_STAT B43_PHY_N(0x0C7) /* Sample status */
  329. #define B43_NPHY_GPIO_LOOEN B43_PHY_N(0x0C8) /* GPIO low out enable */
  330. #define B43_NPHY_GPIO_HIOEN B43_PHY_N(0x0C9) /* GPIO high out enable */
  331. #define B43_NPHY_GPIO_SEL B43_PHY_N(0x0CA) /* GPIO select */
  332. #define B43_NPHY_GPIO_CLKCTL B43_PHY_N(0x0CB) /* GPIO clock control */
  333. #define B43_NPHY_TXF_20CO_AS0 B43_PHY_N(0x0CC) /* TX filter 20 coeff A stage 0 */
  334. #define B43_NPHY_TXF_20CO_AS1 B43_PHY_N(0x0CD) /* TX filter 20 coeff A stage 1 */
  335. #define B43_NPHY_TXF_20CO_AS2 B43_PHY_N(0x0CE) /* TX filter 20 coeff A stage 2 */
  336. #define B43_NPHY_TXF_20CO_B32S0 B43_PHY_N(0x0CF) /* TX filter 20 coeff B32 stage 0 */
  337. #define B43_NPHY_TXF_20CO_B1S0 B43_PHY_N(0x0D0) /* TX filter 20 coeff B1 stage 0 */
  338. #define B43_NPHY_TXF_20CO_B32S1 B43_PHY_N(0x0D1) /* TX filter 20 coeff B32 stage 1 */
  339. #define B43_NPHY_TXF_20CO_B1S1 B43_PHY_N(0x0D2) /* TX filter 20 coeff B1 stage 1 */
  340. #define B43_NPHY_TXF_20CO_B32S2 B43_PHY_N(0x0D3) /* TX filter 20 coeff B32 stage 2 */
  341. #define B43_NPHY_TXF_20CO_B1S2 B43_PHY_N(0x0D4) /* TX filter 20 coeff B1 stage 2 */
  342. #define B43_NPHY_SIGFLDTOL B43_PHY_N(0x0D5) /* Signal fld tolerance */
  343. #define B43_NPHY_TXSERFLD B43_PHY_N(0x0D6) /* TX service field */
  344. #define B43_NPHY_AFESEQ_RX2TX_PUD B43_PHY_N(0x0D7) /* AFE seq RX2TX power up/down delay */
  345. #define B43_NPHY_AFESEQ_TX2RX_PUD B43_PHY_N(0x0D8) /* AFE seq TX2RX power up/down delay */
  346. #define B43_NPHY_TGNSYNC_SCRAMI0 B43_PHY_N(0x0D9) /* TGNsync scram init 0 */
  347. #define B43_NPHY_TGNSYNC_SCRAMI1 B43_PHY_N(0x0DA) /* TGNsync scram init 1 */
  348. #define B43_NPHY_INITSWIZPATTLEG B43_PHY_N(0x0DB) /* Initial swizzle pattern leg */
  349. #define B43_NPHY_BPHY_CTL3 B43_PHY_N(0x0DC) /* B PHY control 3 */
  350. #define B43_NPHY_BPHY_CTL3_SCALE 0x00FF /* Scale */
  351. #define B43_NPHY_BPHY_CTL3_SCALE_SHIFT 0
  352. #define B43_NPHY_BPHY_CTL3_FSC 0xFF00 /* Frame start count value */
  353. #define B43_NPHY_BPHY_CTL3_FSC_SHIFT 8
  354. #define B43_NPHY_BPHY_CTL4 B43_PHY_N(0x0DD) /* B PHY control 4 */
  355. #define B43_NPHY_C1_TXBBMULT B43_PHY_N(0x0DE) /* Core 1 TX BB multiplier */
  356. #define B43_NPHY_C2_TXBBMULT B43_PHY_N(0x0DF) /* Core 2 TX BB multiplier */
  357. #define B43_NPHY_TXF_40CO_AS0 B43_PHY_N(0x0E1) /* TX filter 40 coeff A stage 0 */
  358. #define B43_NPHY_TXF_40CO_AS1 B43_PHY_N(0x0E2) /* TX filter 40 coeff A stage 1 */
  359. #define B43_NPHY_TXF_40CO_AS2 B43_PHY_N(0x0E3) /* TX filter 40 coeff A stage 2 */
  360. #define B43_NPHY_TXF_40CO_B32S0 B43_PHY_N(0x0E4) /* TX filter 40 coeff B32 stage 0 */
  361. #define B43_NPHY_TXF_40CO_B1S0 B43_PHY_N(0x0E5) /* TX filter 40 coeff B1 stage 0 */
  362. #define B43_NPHY_TXF_40CO_B32S1 B43_PHY_N(0x0E6) /* TX filter 40 coeff B32 stage 1 */
  363. #define B43_NPHY_TXF_40CO_B1S1 B43_PHY_N(0x0E7) /* TX filter 40 coeff B1 stage 1 */
  364. #define B43_NPHY_REV3_RFCTL_OVER0 B43_PHY_N(0x0E7)
  365. #define B43_NPHY_TXF_40CO_B32S2 B43_PHY_N(0x0E8) /* TX filter 40 coeff B32 stage 2 */
  366. #define B43_NPHY_TXF_40CO_B1S2 B43_PHY_N(0x0E9) /* TX filter 40 coeff B1 stage 2 */
  367. #define B43_NPHY_BIST_STAT2 B43_PHY_N(0x0EA) /* BIST status 2 */
  368. #define B43_NPHY_BIST_STAT3 B43_PHY_N(0x0EB) /* BIST status 3 */
  369. #define B43_NPHY_RFCTL_OVER B43_PHY_N(0x0EC) /* RF control override */
  370. #define B43_NPHY_REV3_RFCTL_OVER1 B43_PHY_N(0x0EC)
  371. #define B43_NPHY_MIMOCFG B43_PHY_N(0x0ED) /* MIMO config */
  372. #define B43_NPHY_MIMOCFG_GFMIX 0x0004 /* Greenfield or mixed mode */
  373. #define B43_NPHY_MIMOCFG_AUTO 0x0100 /* Greenfield/mixed mode auto */
  374. #define B43_NPHY_RADAR_BLNKCTL B43_PHY_N(0x0EE) /* Radar blank control */
  375. #define B43_NPHY_A0RADAR_FIFOCTL B43_PHY_N(0x0EF) /* Antenna 0 radar FIFO control */
  376. #define B43_NPHY_A1RADAR_FIFOCTL B43_PHY_N(0x0F0) /* Antenna 1 radar FIFO control */
  377. #define B43_NPHY_A0RADAR_FIFODAT B43_PHY_N(0x0F1) /* Antenna 0 radar FIFO data */
  378. #define B43_NPHY_A1RADAR_FIFODAT B43_PHY_N(0x0F2) /* Antenna 1 radar FIFO data */
  379. #define B43_NPHY_RADAR_THRES0 B43_PHY_N(0x0F3) /* Radar threshold 0 */
  380. #define B43_NPHY_RADAR_THRES1 B43_PHY_N(0x0F4) /* Radar threshold 1 */
  381. #define B43_NPHY_RADAR_THRES0R B43_PHY_N(0x0F5) /* Radar threshold 0R */
  382. #define B43_NPHY_RADAR_THRES1R B43_PHY_N(0x0F6) /* Radar threshold 1R */
  383. #define B43_NPHY_CSEN_20IN40_DLEN B43_PHY_N(0x0F7) /* Carrier sense 20 in 40 dwell length */
  384. #define B43_NPHY_RFCTL_LUT_TRSW_LO1 B43_PHY_N(0x0F8) /* RF control LUT TRSW lower 1 */
  385. #define B43_NPHY_RFCTL_LUT_TRSW_UP1 B43_PHY_N(0x0F9) /* RF control LUT TRSW upper 1 */
  386. #define B43_NPHY_RFCTL_LUT_TRSW_LO2 B43_PHY_N(0x0FA) /* RF control LUT TRSW lower 2 */
  387. #define B43_NPHY_RFCTL_LUT_TRSW_UP2 B43_PHY_N(0x0FB) /* RF control LUT TRSW upper 2 */
  388. #define B43_NPHY_RFCTL_LUT_TRSW_LO3 B43_PHY_N(0x0FC) /* RF control LUT TRSW lower 3 */
  389. #define B43_NPHY_RFCTL_LUT_TRSW_UP3 B43_PHY_N(0x0FD) /* RF control LUT TRSW upper 3 */
  390. #define B43_NPHY_RFCTL_LUT_TRSW_LO4 B43_PHY_N(0x0FE) /* RF control LUT TRSW lower 4 */
  391. #define B43_NPHY_RFCTL_LUT_TRSW_UP4 B43_PHY_N(0x0FF) /* RF control LUT TRSW upper 4 */
  392. #define B43_NPHY_RFCTL_LUT_LNAPA1 B43_PHY_N(0x100) /* RF control LUT LNA PA 1 */
  393. #define B43_NPHY_RFCTL_LUT_LNAPA2 B43_PHY_N(0x101) /* RF control LUT LNA PA 2 */
  394. #define B43_NPHY_RFCTL_LUT_LNAPA3 B43_PHY_N(0x102) /* RF control LUT LNA PA 3 */
  395. #define B43_NPHY_RFCTL_LUT_LNAPA4 B43_PHY_N(0x103) /* RF control LUT LNA PA 4 */
  396. #define B43_NPHY_TGNSYNC_CRCM0 B43_PHY_N(0x104) /* TGNsync CRC mask 0 */
  397. #define B43_NPHY_TGNSYNC_CRCM1 B43_PHY_N(0x105) /* TGNsync CRC mask 1 */
  398. #define B43_NPHY_TGNSYNC_CRCM2 B43_PHY_N(0x106) /* TGNsync CRC mask 2 */
  399. #define B43_NPHY_TGNSYNC_CRCM3 B43_PHY_N(0x107) /* TGNsync CRC mask 3 */
  400. #define B43_NPHY_TGNSYNC_CRCM4 B43_PHY_N(0x108) /* TGNsync CRC mask 4 */
  401. #define B43_NPHY_CRCPOLY B43_PHY_N(0x109) /* CRC polynomial */
  402. #define B43_NPHY_SIGCNT B43_PHY_N(0x10A) /* # sig count */
  403. #define B43_NPHY_SIGSTARTBIT_CTL B43_PHY_N(0x10B) /* Sig start bit control */
  404. #define B43_NPHY_CRCPOLY_ORDER B43_PHY_N(0x10C) /* CRC polynomial order */
  405. #define B43_NPHY_RFCTL_CST0 B43_PHY_N(0x10D) /* RF control core swap table 0 */
  406. #define B43_NPHY_RFCTL_CST1 B43_PHY_N(0x10E) /* RF control core swap table 1 */
  407. #define B43_NPHY_RFCTL_CST2O B43_PHY_N(0x10F) /* RF control core swap table 2 + others */
  408. #define B43_NPHY_BPHY_CTL5 B43_PHY_N(0x111) /* B PHY control 5 */
  409. #define B43_NPHY_RFSEQ_LPFBW B43_PHY_N(0x112) /* RF seq LPF bandwidth */
  410. #define B43_NPHY_TSSIBIAS1 B43_PHY_N(0x114) /* TSSI bias val 1 */
  411. #define B43_NPHY_TSSIBIAS2 B43_PHY_N(0x115) /* TSSI bias val 2 */
  412. #define B43_NPHY_TSSIBIAS_BIAS 0x00FF /* Bias */
  413. #define B43_NPHY_TSSIBIAS_BIAS_SHIFT 0
  414. #define B43_NPHY_TSSIBIAS_VAL 0xFF00 /* Value */
  415. #define B43_NPHY_TSSIBIAS_VAL_SHIFT 8
  416. #define B43_NPHY_ESTPWR1 B43_PHY_N(0x118) /* Estimated power 1 */
  417. #define B43_NPHY_ESTPWR2 B43_PHY_N(0x119) /* Estimated power 2 */
  418. #define B43_NPHY_ESTPWR_PWR 0x00FF /* Estimated power */
  419. #define B43_NPHY_ESTPWR_PWR_SHIFT 0
  420. #define B43_NPHY_ESTPWR_VALID 0x0100 /* Estimated power valid */
  421. #define B43_NPHY_TSSI_MAXTXFDT B43_PHY_N(0x11C) /* TSSI max TX frame delay time */
  422. #define B43_NPHY_TSSI_MAXTXFDT_VAL 0x00FF /* max TX frame delay time */
  423. #define B43_NPHY_TSSI_MAXTXFDT_VAL_SHIFT 0
  424. #define B43_NPHY_TSSI_MAXTDT B43_PHY_N(0x11D) /* TSSI max TSSI delay time */
  425. #define B43_NPHY_TSSI_MAXTDT_VAL 0x00FF /* max TSSI delay time */
  426. #define B43_NPHY_TSSI_MAXTDT_VAL_SHIFT 0
  427. #define B43_NPHY_ITSSI1 B43_PHY_N(0x11E) /* TSSI idle 1 */
  428. #define B43_NPHY_ITSSI2 B43_PHY_N(0x11F) /* TSSI idle 2 */
  429. #define B43_NPHY_ITSSI_VAL 0x00FF /* Idle TSSI */
  430. #define B43_NPHY_ITSSI_VAL_SHIFT 0
  431. #define B43_NPHY_TSSIMODE B43_PHY_N(0x122) /* TSSI mode */
  432. #define B43_NPHY_TSSIMODE_EN 0x0001 /* TSSI enable */
  433. #define B43_NPHY_TSSIMODE_PDEN 0x0002 /* Power det enable */
  434. #define B43_NPHY_RXMACIFM B43_PHY_N(0x123) /* RX Macif mode */
  435. #define B43_NPHY_CRSIT_COCNT_LO B43_PHY_N(0x124) /* CRS idle time CRS-on count (low) */
  436. #define B43_NPHY_CRSIT_COCNT_HI B43_PHY_N(0x125) /* CRS idle time CRS-on count (high) */
  437. #define B43_NPHY_CRSIT_MTCNT_LO B43_PHY_N(0x126) /* CRS idle time measure time count (low) */
  438. #define B43_NPHY_CRSIT_MTCNT_HI B43_PHY_N(0x127) /* CRS idle time measure time count (high) */
  439. #define B43_NPHY_SAMTWC B43_PHY_N(0x128) /* Sample tail wait count */
  440. #define B43_NPHY_IQEST_CMD B43_PHY_N(0x129) /* I/Q estimate command */
  441. #define B43_NPHY_IQEST_CMD_START 0x0001 /* Start */
  442. #define B43_NPHY_IQEST_CMD_MODE 0x0002 /* Mode */
  443. #define B43_NPHY_IQEST_WT B43_PHY_N(0x12A) /* I/Q estimate wait time */
  444. #define B43_NPHY_IQEST_WT_VAL 0x00FF /* Wait time */
  445. #define B43_NPHY_IQEST_WT_VAL_SHIFT 0
  446. #define B43_NPHY_IQEST_SAMCNT B43_PHY_N(0x12B) /* I/Q estimate sample count */
  447. #define B43_NPHY_IQEST_IQACC_LO0 B43_PHY_N(0x12C) /* I/Q estimate I/Q acc lo 0 */
  448. #define B43_NPHY_IQEST_IQACC_HI0 B43_PHY_N(0x12D) /* I/Q estimate I/Q acc hi 0 */
  449. #define B43_NPHY_IQEST_IPACC_LO0 B43_PHY_N(0x12E) /* I/Q estimate I power acc lo 0 */
  450. #define B43_NPHY_IQEST_IPACC_HI0 B43_PHY_N(0x12F) /* I/Q estimate I power acc hi 0 */
  451. #define B43_NPHY_IQEST_QPACC_LO0 B43_PHY_N(0x130) /* I/Q estimate Q power acc lo 0 */
  452. #define B43_NPHY_IQEST_QPACC_HI0 B43_PHY_N(0x131) /* I/Q estimate Q power acc hi 0 */
  453. #define B43_NPHY_IQEST_IQACC_LO1 B43_PHY_N(0x134) /* I/Q estimate I/Q acc lo 1 */
  454. #define B43_NPHY_IQEST_IQACC_HI1 B43_PHY_N(0x135) /* I/Q estimate I/Q acc hi 1 */
  455. #define B43_NPHY_IQEST_IPACC_LO1 B43_PHY_N(0x136) /* I/Q estimate I power acc lo 1 */
  456. #define B43_NPHY_IQEST_IPACC_HI1 B43_PHY_N(0x137) /* I/Q estimate I power acc hi 1 */
  457. #define B43_NPHY_IQEST_QPACC_LO1 B43_PHY_N(0x138) /* I/Q estimate Q power acc lo 1 */
  458. #define B43_NPHY_IQEST_QPACC_HI1 B43_PHY_N(0x139) /* I/Q estimate Q power acc hi 1 */
  459. #define B43_NPHY_MIMO_CRSTXEXT B43_PHY_N(0x13A) /* MIMO PHY CRS TX extension */
  460. #define B43_NPHY_PWRDET1 B43_PHY_N(0x13B) /* Power det 1 */
  461. #define B43_NPHY_PWRDET2 B43_PHY_N(0x13C) /* Power det 2 */
  462. #define B43_NPHY_MAXRSSI_DTIME B43_PHY_N(0x13F) /* RSSI max RSSI delay time */
  463. #define B43_NPHY_PIL_DW0 B43_PHY_N(0x141) /* Pilot data weight 0 */
  464. #define B43_NPHY_PIL_DW1 B43_PHY_N(0x142) /* Pilot data weight 1 */
  465. #define B43_NPHY_PIL_DW2 B43_PHY_N(0x143) /* Pilot data weight 2 */
  466. #define B43_NPHY_PIL_DW_BPSK 0x000F /* BPSK */
  467. #define B43_NPHY_PIL_DW_BPSK_SHIFT 0
  468. #define B43_NPHY_PIL_DW_QPSK 0x00F0 /* QPSK */
  469. #define B43_NPHY_PIL_DW_QPSK_SHIFT 4
  470. #define B43_NPHY_PIL_DW_16QAM 0x0F00 /* 16-QAM */
  471. #define B43_NPHY_PIL_DW_16QAM_SHIFT 8
  472. #define B43_NPHY_PIL_DW_64QAM 0xF000 /* 64-QAM */
  473. #define B43_NPHY_PIL_DW_64QAM_SHIFT 12
  474. #define B43_NPHY_FMDEM_CFG B43_PHY_N(0x144) /* FM demodulation config */
  475. #define B43_NPHY_PHASETR_A0 B43_PHY_N(0x145) /* Phase track alpha 0 */
  476. #define B43_NPHY_PHASETR_A1 B43_PHY_N(0x146) /* Phase track alpha 1 */
  477. #define B43_NPHY_PHASETR_A2 B43_PHY_N(0x147) /* Phase track alpha 2 */
  478. #define B43_NPHY_PHASETR_B0 B43_PHY_N(0x148) /* Phase track beta 0 */
  479. #define B43_NPHY_PHASETR_B1 B43_PHY_N(0x149) /* Phase track beta 1 */
  480. #define B43_NPHY_PHASETR_B2 B43_PHY_N(0x14A) /* Phase track beta 2 */
  481. #define B43_NPHY_PHASETR_CHG0 B43_PHY_N(0x14B) /* Phase track change 0 */
  482. #define B43_NPHY_PHASETR_CHG1 B43_PHY_N(0x14C) /* Phase track change 1 */
  483. #define B43_NPHY_PHASETW_OFF B43_PHY_N(0x14D) /* Phase track offset */
  484. #define B43_NPHY_RFCTL_DBG B43_PHY_N(0x14E) /* RF control debug */
  485. #define B43_NPHY_CCK_SHIFTB_REF B43_PHY_N(0x150) /* CCK shiftbits reference var */
  486. #define B43_NPHY_OVER_DGAIN0 B43_PHY_N(0x152) /* Override digital gain 0 */
  487. #define B43_NPHY_OVER_DGAIN1 B43_PHY_N(0x153) /* Override digital gain 1 */
  488. #define B43_NPHY_OVER_DGAIN_FDGV 0x0007 /* Force digital gain value */
  489. #define B43_NPHY_OVER_DGAIN_FDGV_SHIFT 0
  490. #define B43_NPHY_OVER_DGAIN_FDGEN 0x0008 /* Force digital gain enable */
  491. #define B43_NPHY_OVER_DGAIN_CCKDGECV 0xFF00 /* CCK digital gain enable count value */
  492. #define B43_NPHY_OVER_DGAIN_CCKDGECV_SHIFT 8
  493. #define B43_NPHY_BIST_STAT4 B43_PHY_N(0x156) /* BIST status 4 */
  494. #define B43_NPHY_RADAR_MAL B43_PHY_N(0x157) /* Radar MA length */
  495. #define B43_NPHY_RADAR_SRCCTL B43_PHY_N(0x158) /* Radar search control */
  496. #define B43_NPHY_VLD_DTSIG B43_PHY_N(0x159) /* VLD data tones sig */
  497. #define B43_NPHY_VLD_DTDAT B43_PHY_N(0x15A) /* VLD data tones data */
  498. #define B43_NPHY_C1_BPHY_RXIQCA0 B43_PHY_N(0x15B) /* Core 1 B PHY RX I/Q comp A0 */
  499. #define B43_NPHY_C1_BPHY_RXIQCB0 B43_PHY_N(0x15C) /* Core 1 B PHY RX I/Q comp B0 */
  500. #define B43_NPHY_C2_BPHY_RXIQCA1 B43_PHY_N(0x15D) /* Core 2 B PHY RX I/Q comp A1 */
  501. #define B43_NPHY_C2_BPHY_RXIQCB1 B43_PHY_N(0x15E) /* Core 2 B PHY RX I/Q comp B1 */
  502. #define B43_NPHY_FREQGAIN0 B43_PHY_N(0x160) /* Frequency gain 0 */
  503. #define B43_NPHY_FREQGAIN1 B43_PHY_N(0x161) /* Frequency gain 1 */
  504. #define B43_NPHY_FREQGAIN2 B43_PHY_N(0x162) /* Frequency gain 2 */
  505. #define B43_NPHY_FREQGAIN3 B43_PHY_N(0x163) /* Frequency gain 3 */
  506. #define B43_NPHY_FREQGAIN4 B43_PHY_N(0x164) /* Frequency gain 4 */
  507. #define B43_NPHY_FREQGAIN5 B43_PHY_N(0x165) /* Frequency gain 5 */
  508. #define B43_NPHY_FREQGAIN6 B43_PHY_N(0x166) /* Frequency gain 6 */
  509. #define B43_NPHY_FREQGAIN7 B43_PHY_N(0x167) /* Frequency gain 7 */
  510. #define B43_NPHY_FREQGAIN_BYPASS B43_PHY_N(0x168) /* Frequency gain bypass */
  511. #define B43_NPHY_TRLOSS B43_PHY_N(0x169) /* TR loss value */
  512. #define B43_NPHY_C1_ADCCLIP B43_PHY_N(0x16A) /* Core 1 ADC clip */
  513. #define B43_NPHY_C2_ADCCLIP B43_PHY_N(0x16B) /* Core 2 ADC clip */
  514. #define B43_NPHY_LTRN_OFFGAIN B43_PHY_N(0x16F) /* LTRN offset gain */
  515. #define B43_NPHY_LTRN_OFF B43_PHY_N(0x170) /* LTRN offset */
  516. #define B43_NPHY_NRDATAT_WWISE20SIG B43_PHY_N(0x171) /* # data tones WWiSE 20 sig */
  517. #define B43_NPHY_NRDATAT_WWISE40SIG B43_PHY_N(0x172) /* # data tones WWiSE 40 sig */
  518. #define B43_NPHY_NRDATAT_TGNSYNC20SIG B43_PHY_N(0x173) /* # data tones TGNsync 20 sig */
  519. #define B43_NPHY_NRDATAT_TGNSYNC40SIG B43_PHY_N(0x174) /* # data tones TGNsync 40 sig */
  520. #define B43_NPHY_WWISE_CRCM0 B43_PHY_N(0x175) /* WWiSE CRC mask 0 */
  521. #define B43_NPHY_WWISE_CRCM1 B43_PHY_N(0x176) /* WWiSE CRC mask 1 */
  522. #define B43_NPHY_WWISE_CRCM2 B43_PHY_N(0x177) /* WWiSE CRC mask 2 */
  523. #define B43_NPHY_WWISE_CRCM3 B43_PHY_N(0x178) /* WWiSE CRC mask 3 */
  524. #define B43_NPHY_WWISE_CRCM4 B43_PHY_N(0x179) /* WWiSE CRC mask 4 */
  525. #define B43_NPHY_CHANEST_CDDSH B43_PHY_N(0x17A) /* Channel estimate CDD shift */
  526. #define B43_NPHY_HTAGC_WCNT B43_PHY_N(0x17B) /* HT ADC wait counters */
  527. #define B43_NPHY_SQPARM B43_PHY_N(0x17C) /* SQ params */
  528. #define B43_NPHY_MCSDUP6M B43_PHY_N(0x17D) /* MCS dup 6M */
  529. #define B43_NPHY_NDATAT_DUP40 B43_PHY_N(0x17E) /* # data tones dup 40 */
  530. #define B43_NPHY_DUP40_TGNSYNC_CYCD B43_PHY_N(0x17F) /* Dup40 TGNsync cycle data */
  531. #define B43_NPHY_DUP40_GFBL B43_PHY_N(0x180) /* Dup40 GF format BL address */
  532. #define B43_NPHY_DUP40_BL B43_PHY_N(0x181) /* Dup40 format BL address */
  533. #define B43_NPHY_LEGDUP_FTA B43_PHY_N(0x182) /* Legacy dup frm table address */
  534. #define B43_NPHY_PACPROC_DBG B43_PHY_N(0x183) /* Packet processing debug */
  535. #define B43_NPHY_PIL_CYC1 B43_PHY_N(0x184) /* Pilot cycle counter 1 */
  536. #define B43_NPHY_PIL_CYC2 B43_PHY_N(0x185) /* Pilot cycle counter 2 */
  537. #define B43_NPHY_TXF_20CO_S0A1 B43_PHY_N(0x186) /* TX filter 20 coeff stage 0 A1 */
  538. #define B43_NPHY_TXF_20CO_S0A2 B43_PHY_N(0x187) /* TX filter 20 coeff stage 0 A2 */
  539. #define B43_NPHY_TXF_20CO_S1A1 B43_PHY_N(0x188) /* TX filter 20 coeff stage 1 A1 */
  540. #define B43_NPHY_TXF_20CO_S1A2 B43_PHY_N(0x189) /* TX filter 20 coeff stage 1 A2 */
  541. #define B43_NPHY_TXF_20CO_S2A1 B43_PHY_N(0x18A) /* TX filter 20 coeff stage 2 A1 */
  542. #define B43_NPHY_TXF_20CO_S2A2 B43_PHY_N(0x18B) /* TX filter 20 coeff stage 2 A2 */
  543. #define B43_NPHY_TXF_20CO_S0B1 B43_PHY_N(0x18C) /* TX filter 20 coeff stage 0 B1 */
  544. #define B43_NPHY_TXF_20CO_S0B2 B43_PHY_N(0x18D) /* TX filter 20 coeff stage 0 B2 */
  545. #define B43_NPHY_TXF_20CO_S0B3 B43_PHY_N(0x18E) /* TX filter 20 coeff stage 0 B3 */
  546. #define B43_NPHY_TXF_20CO_S1B1 B43_PHY_N(0x18F) /* TX filter 20 coeff stage 1 B1 */
  547. #define B43_NPHY_TXF_20CO_S1B2 B43_PHY_N(0x190) /* TX filter 20 coeff stage 1 B2 */
  548. #define B43_NPHY_TXF_20CO_S1B3 B43_PHY_N(0x191) /* TX filter 20 coeff stage 1 B3 */
  549. #define B43_NPHY_TXF_20CO_S2B1 B43_PHY_N(0x192) /* TX filter 20 coeff stage 2 B1 */
  550. #define B43_NPHY_TXF_20CO_S2B2 B43_PHY_N(0x193) /* TX filter 20 coeff stage 2 B2 */
  551. #define B43_NPHY_TXF_20CO_S2B3 B43_PHY_N(0x194) /* TX filter 20 coeff stage 2 B3 */
  552. #define B43_NPHY_TXF_40CO_S0A1 B43_PHY_N(0x195) /* TX filter 40 coeff stage 0 A1 */
  553. #define B43_NPHY_TXF_40CO_S0A2 B43_PHY_N(0x196) /* TX filter 40 coeff stage 0 A2 */
  554. #define B43_NPHY_TXF_40CO_S1A1 B43_PHY_N(0x197) /* TX filter 40 coeff stage 1 A1 */
  555. #define B43_NPHY_TXF_40CO_S1A2 B43_PHY_N(0x198) /* TX filter 40 coeff stage 1 A2 */
  556. #define B43_NPHY_TXF_40CO_S2A1 B43_PHY_N(0x199) /* TX filter 40 coeff stage 2 A1 */
  557. #define B43_NPHY_TXF_40CO_S2A2 B43_PHY_N(0x19A) /* TX filter 40 coeff stage 2 A2 */
  558. #define B43_NPHY_TXF_40CO_S0B1 B43_PHY_N(0x19B) /* TX filter 40 coeff stage 0 B1 */
  559. #define B43_NPHY_TXF_40CO_S0B2 B43_PHY_N(0x19C) /* TX filter 40 coeff stage 0 B2 */
  560. #define B43_NPHY_TXF_40CO_S0B3 B43_PHY_N(0x19D) /* TX filter 40 coeff stage 0 B3 */
  561. #define B43_NPHY_TXF_40CO_S1B1 B43_PHY_N(0x19E) /* TX filter 40 coeff stage 1 B1 */
  562. #define B43_NPHY_TXF_40CO_S1B2 B43_PHY_N(0x19F) /* TX filter 40 coeff stage 1 B2 */
  563. #define B43_NPHY_TXF_40CO_S1B3 B43_PHY_N(0x1A0) /* TX filter 40 coeff stage 1 B3 */
  564. #define B43_NPHY_TXF_40CO_S2B1 B43_PHY_N(0x1A1) /* TX filter 40 coeff stage 2 B1 */
  565. #define B43_NPHY_TXF_40CO_S2B2 B43_PHY_N(0x1A2) /* TX filter 40 coeff stage 2 B2 */
  566. #define B43_NPHY_TXF_40CO_S2B3 B43_PHY_N(0x1A3) /* TX filter 40 coeff stage 2 B3 */
  567. #define B43_NPHY_RSSIMC_0I_RSSI_X B43_PHY_N(0x1A4) /* RSSI multiplication coefficient 0 I RSSI X */
  568. #define B43_NPHY_RSSIMC_0I_RSSI_Y B43_PHY_N(0x1A5) /* RSSI multiplication coefficient 0 I RSSI Y */
  569. #define B43_NPHY_RSSIMC_0I_RSSI_Z B43_PHY_N(0x1A6) /* RSSI multiplication coefficient 0 I RSSI Z */
  570. #define B43_NPHY_RSSIMC_0I_TBD B43_PHY_N(0x1A7) /* RSSI multiplication coefficient 0 I TBD */
  571. #define B43_NPHY_RSSIMC_0I_PWRDET B43_PHY_N(0x1A8) /* RSSI multiplication coefficient 0 I power det */
  572. #define B43_NPHY_RSSIMC_0I_TSSI B43_PHY_N(0x1A9) /* RSSI multiplication coefficient 0 I TSSI */
  573. #define B43_NPHY_RSSIMC_0Q_RSSI_X B43_PHY_N(0x1AA) /* RSSI multiplication coefficient 0 Q RSSI X */
  574. #define B43_NPHY_RSSIMC_0Q_RSSI_Y B43_PHY_N(0x1AB) /* RSSI multiplication coefficient 0 Q RSSI Y */
  575. #define B43_NPHY_RSSIMC_0Q_RSSI_Z B43_PHY_N(0x1AC) /* RSSI multiplication coefficient 0 Q RSSI Z */
  576. #define B43_NPHY_RSSIMC_0Q_TBD B43_PHY_N(0x1AD) /* RSSI multiplication coefficient 0 Q TBD */
  577. #define B43_NPHY_RSSIMC_0Q_PWRDET B43_PHY_N(0x1AE) /* RSSI multiplication coefficient 0 Q power det */
  578. #define B43_NPHY_RSSIMC_0Q_TSSI B43_PHY_N(0x1AF) /* RSSI multiplication coefficient 0 Q TSSI */
  579. #define B43_NPHY_RSSIMC_1I_RSSI_X B43_PHY_N(0x1B0) /* RSSI multiplication coefficient 1 I RSSI X */
  580. #define B43_NPHY_RSSIMC_1I_RSSI_Y B43_PHY_N(0x1B1) /* RSSI multiplication coefficient 1 I RSSI Y */
  581. #define B43_NPHY_RSSIMC_1I_RSSI_Z B43_PHY_N(0x1B2) /* RSSI multiplication coefficient 1 I RSSI Z */
  582. #define B43_NPHY_RSSIMC_1I_TBD B43_PHY_N(0x1B3) /* RSSI multiplication coefficient 1 I TBD */
  583. #define B43_NPHY_RSSIMC_1I_PWRDET B43_PHY_N(0x1B4) /* RSSI multiplication coefficient 1 I power det */
  584. #define B43_NPHY_RSSIMC_1I_TSSI B43_PHY_N(0x1B5) /* RSSI multiplication coefficient 1 I TSSI */
  585. #define B43_NPHY_RSSIMC_1Q_RSSI_X B43_PHY_N(0x1B6) /* RSSI multiplication coefficient 1 Q RSSI X */
  586. #define B43_NPHY_RSSIMC_1Q_RSSI_Y B43_PHY_N(0x1B7) /* RSSI multiplication coefficient 1 Q RSSI Y */
  587. #define B43_NPHY_RSSIMC_1Q_RSSI_Z B43_PHY_N(0x1B8) /* RSSI multiplication coefficient 1 Q RSSI Z */
  588. #define B43_NPHY_RSSIMC_1Q_TBD B43_PHY_N(0x1B9) /* RSSI multiplication coefficient 1 Q TBD */
  589. #define B43_NPHY_RSSIMC_1Q_PWRDET B43_PHY_N(0x1BA) /* RSSI multiplication coefficient 1 Q power det */
  590. #define B43_NPHY_RSSIMC_1Q_TSSI B43_PHY_N(0x1BB) /* RSSI multiplication coefficient 1 Q TSSI */
  591. #define B43_NPHY_SAMC_WCNT B43_PHY_N(0x1BC) /* Sample collect wait counter */
  592. #define B43_NPHY_PTHROUGH_CNT B43_PHY_N(0x1BD) /* Pass-through counter */
  593. #define B43_NPHY_LTRN_OFF_G20L B43_PHY_N(0x1C4) /* LTRN offset gain 20L */
  594. #define B43_NPHY_LTRN_OFF_20L B43_PHY_N(0x1C5) /* LTRN offset 20L */
  595. #define B43_NPHY_LTRN_OFF_G20U B43_PHY_N(0x1C6) /* LTRN offset gain 20U */
  596. #define B43_NPHY_LTRN_OFF_20U B43_PHY_N(0x1C7) /* LTRN offset 20U */
  597. #define B43_NPHY_DSSSCCK_GAINSL B43_PHY_N(0x1C8) /* DSSS/CCK gain settle length */
  598. #define B43_NPHY_GPIO_LOOUT B43_PHY_N(0x1C9) /* GPIO low out */
  599. #define B43_NPHY_GPIO_HIOUT B43_PHY_N(0x1CA) /* GPIO high out */
  600. #define B43_NPHY_CRS_CHECK B43_PHY_N(0x1CB) /* CRS check */
  601. #define B43_NPHY_ML_LOGSS_RAT B43_PHY_N(0x1CC) /* ML/logss ratio */
  602. #define B43_NPHY_DUPSCALE B43_PHY_N(0x1CD) /* Dup scale */
  603. #define B43_NPHY_BW1A B43_PHY_N(0x1CE) /* BW 1A */
  604. #define B43_NPHY_BW2 B43_PHY_N(0x1CF) /* BW 2 */
  605. #define B43_NPHY_BW3 B43_PHY_N(0x1D0) /* BW 3 */
  606. #define B43_NPHY_BW4 B43_PHY_N(0x1D1) /* BW 4 */
  607. #define B43_NPHY_BW5 B43_PHY_N(0x1D2) /* BW 5 */
  608. #define B43_NPHY_BW6 B43_PHY_N(0x1D3) /* BW 6 */
  609. #define B43_NPHY_COALEN0 B43_PHY_N(0x1D4) /* Coarse length 0 */
  610. #define B43_NPHY_COALEN1 B43_PHY_N(0x1D5) /* Coarse length 1 */
  611. #define B43_NPHY_CRSTHRES_1U B43_PHY_N(0x1D6) /* CRS threshold 1 U */
  612. #define B43_NPHY_CRSTHRES_2U B43_PHY_N(0x1D7) /* CRS threshold 2 U */
  613. #define B43_NPHY_CRSTHRES_3U B43_PHY_N(0x1D8) /* CRS threshold 3 U */
  614. #define B43_NPHY_CRSCTL_U B43_PHY_N(0x1D9) /* CRS control U */
  615. #define B43_NPHY_CRSTHRES_1L B43_PHY_N(0x1DA) /* CRS threshold 1 L */
  616. #define B43_NPHY_CRSTHRES_2L B43_PHY_N(0x1DB) /* CRS threshold 2 L */
  617. #define B43_NPHY_CRSTHRES_3L B43_PHY_N(0x1DC) /* CRS threshold 3 L */
  618. #define B43_NPHY_CRSCTL_L B43_PHY_N(0x1DD) /* CRS control L */
  619. #define B43_NPHY_STRA_1U B43_PHY_N(0x1DE) /* STR address 1 U */
  620. #define B43_NPHY_STRA_2U B43_PHY_N(0x1DF) /* STR address 2 U */
  621. #define B43_NPHY_STRA_1L B43_PHY_N(0x1E0) /* STR address 1 L */
  622. #define B43_NPHY_STRA_2L B43_PHY_N(0x1E1) /* STR address 2 L */
  623. #define B43_NPHY_CRSCHECK1 B43_PHY_N(0x1E2) /* CRS check 1 */
  624. #define B43_NPHY_CRSCHECK2 B43_PHY_N(0x1E3) /* CRS check 2 */
  625. #define B43_NPHY_CRSCHECK3 B43_PHY_N(0x1E4) /* CRS check 3 */
  626. #define B43_NPHY_JMPSTP0 B43_PHY_N(0x1E5) /* Jump step 0 */
  627. #define B43_NPHY_JMPSTP1 B43_PHY_N(0x1E6) /* Jump step 1 */
  628. #define B43_NPHY_TXPCTL_CMD B43_PHY_N(0x1E7) /* TX power control command */
  629. #define B43_NPHY_TXPCTL_CMD_INIT 0x007F /* Init */
  630. #define B43_NPHY_TXPCTL_CMD_INIT_SHIFT 0
  631. #define B43_NPHY_TXPCTL_CMD_COEFF 0x2000 /* Power control coefficients */
  632. #define B43_NPHY_TXPCTL_CMD_HWPCTLEN 0x4000 /* Hardware TX power control enable */
  633. #define B43_NPHY_TXPCTL_CMD_PCTLEN 0x8000 /* TX power control enable */
  634. #define B43_NPHY_TXPCTL_N B43_PHY_N(0x1E8) /* TX power control N num */
  635. #define B43_NPHY_TXPCTL_N_TSSID 0x00FF /* N TSSI delay */
  636. #define B43_NPHY_TXPCTL_N_TSSID_SHIFT 0
  637. #define B43_NPHY_TXPCTL_N_NPTIL2 0x0700 /* N PT integer log2 */
  638. #define B43_NPHY_TXPCTL_N_NPTIL2_SHIFT 8
  639. #define B43_NPHY_TXPCTL_ITSSI B43_PHY_N(0x1E9) /* TX power control idle TSSI */
  640. #define B43_NPHY_TXPCTL_ITSSI_0 0x003F /* Idle TSSI 0 */
  641. #define B43_NPHY_TXPCTL_ITSSI_0_SHIFT 0
  642. #define B43_NPHY_TXPCTL_ITSSI_1 0x3F00 /* Idle TSSI 1 */
  643. #define B43_NPHY_TXPCTL_ITSSI_1_SHIFT 8
  644. #define B43_NPHY_TXPCTL_ITSSI_BINF 0x8000 /* Raw TSSI offset bin format */
  645. #define B43_NPHY_TXPCTL_TPWR B43_PHY_N(0x1EA) /* TX power control target power */
  646. #define B43_NPHY_TXPCTL_TPWR_0 0x00FF /* Power 0 */
  647. #define B43_NPHY_TXPCTL_TPWR_0_SHIFT 0
  648. #define B43_NPHY_TXPCTL_TPWR_1 0xFF00 /* Power 1 */
  649. #define B43_NPHY_TXPCTL_TPWR_1_SHIFT 8
  650. #define B43_NPHY_TXPCTL_BIDX B43_PHY_N(0x1EB) /* TX power control base index */
  651. #define B43_NPHY_TXPCTL_BIDX_0 0x007F /* uC base index 0 */
  652. #define B43_NPHY_TXPCTL_BIDX_0_SHIFT 0
  653. #define B43_NPHY_TXPCTL_BIDX_1 0x7F00 /* uC base index 1 */
  654. #define B43_NPHY_TXPCTL_BIDX_1_SHIFT 8
  655. #define B43_NPHY_TXPCTL_BIDX_LOAD 0x8000 /* Load base index */
  656. #define B43_NPHY_TXPCTL_PIDX B43_PHY_N(0x1EC) /* TX power control power index */
  657. #define B43_NPHY_TXPCTL_PIDX_0 0x007F /* uC power index 0 */
  658. #define B43_NPHY_TXPCTL_PIDX_0_SHIFT 0
  659. #define B43_NPHY_TXPCTL_PIDX_1 0x7F00 /* uC power index 1 */
  660. #define B43_NPHY_TXPCTL_PIDX_1_SHIFT 8
  661. #define B43_NPHY_C1_TXPCTL_STAT B43_PHY_N(0x1ED) /* Core 1 TX power control status */
  662. #define B43_NPHY_C2_TXPCTL_STAT B43_PHY_N(0x1EE) /* Core 2 TX power control status */
  663. #define B43_NPHY_TXPCTL_STAT_EST 0x00FF /* Estimated power */
  664. #define B43_NPHY_TXPCTL_STAT_EST_SHIFT 0
  665. #define B43_NPHY_TXPCTL_STAT_BIDX 0x7F00 /* Base index */
  666. #define B43_NPHY_TXPCTL_STAT_BIDX_SHIFT 8
  667. #define B43_NPHY_TXPCTL_STAT_ESTVALID 0x8000 /* Estimated power valid */
  668. #define B43_NPHY_SMALLSGS_LEN B43_PHY_N(0x1EF) /* Small sig gain settle length */
  669. #define B43_NPHY_PHYSTAT_GAIN0 B43_PHY_N(0x1F0) /* PHY stats gain info 0 */
  670. #define B43_NPHY_PHYSTAT_GAIN1 B43_PHY_N(0x1F1) /* PHY stats gain info 1 */
  671. #define B43_NPHY_PHYSTAT_FREQEST B43_PHY_N(0x1F2) /* PHY stats frequency estimate */
  672. #define B43_NPHY_PHYSTAT_ADVRET B43_PHY_N(0x1F3) /* PHY stats ADV retard */
  673. #define B43_NPHY_PHYLB_MODE B43_PHY_N(0x1F4) /* PHY loopback mode */
  674. #define B43_NPHY_TONE_MIDX20_1 B43_PHY_N(0x1F5) /* Tone map index 20/1 */
  675. #define B43_NPHY_TONE_MIDX20_2 B43_PHY_N(0x1F6) /* Tone map index 20/2 */
  676. #define B43_NPHY_TONE_MIDX20_3 B43_PHY_N(0x1F7) /* Tone map index 20/3 */
  677. #define B43_NPHY_TONE_MIDX40_1 B43_PHY_N(0x1F8) /* Tone map index 40/1 */
  678. #define B43_NPHY_TONE_MIDX40_2 B43_PHY_N(0x1F9) /* Tone map index 40/2 */
  679. #define B43_NPHY_TONE_MIDX40_3 B43_PHY_N(0x1FA) /* Tone map index 40/3 */
  680. #define B43_NPHY_TONE_MIDX40_4 B43_PHY_N(0x1FB) /* Tone map index 40/4 */
  681. #define B43_NPHY_PILTONE_MIDX1 B43_PHY_N(0x1FC) /* Pilot tone map index 1 */
  682. #define B43_NPHY_PILTONE_MIDX2 B43_PHY_N(0x1FD) /* Pilot tone map index 2 */
  683. #define B43_NPHY_PILTONE_MIDX3 B43_PHY_N(0x1FE) /* Pilot tone map index 3 */
  684. #define B43_NPHY_TXRIFS_FRDEL B43_PHY_N(0x1FF) /* TX RIFS frame delay */
  685. #define B43_NPHY_AFESEQ_RX2TX_PUD_40M B43_PHY_N(0x200) /* AFE seq rx2tx power up/down delay 40M */
  686. #define B43_NPHY_AFESEQ_TX2RX_PUD_40M B43_PHY_N(0x201) /* AFE seq tx2rx power up/down delay 40M */
  687. #define B43_NPHY_AFESEQ_RX2TX_PUD_20M B43_PHY_N(0x202) /* AFE seq rx2tx power up/down delay 20M */
  688. #define B43_NPHY_AFESEQ_TX2RX_PUD_20M B43_PHY_N(0x203) /* AFE seq tx2rx power up/down delay 20M */
  689. #define B43_NPHY_RX_SIGCTL B43_PHY_N(0x204) /* RX signal control */
  690. #define B43_NPHY_RXPIL_CYCNT0 B43_PHY_N(0x205) /* RX pilot cycle counter 0 */
  691. #define B43_NPHY_RXPIL_CYCNT1 B43_PHY_N(0x206) /* RX pilot cycle counter 1 */
  692. #define B43_NPHY_RXPIL_CYCNT2 B43_PHY_N(0x207) /* RX pilot cycle counter 2 */
  693. #define B43_NPHY_AFESEQ_RX2TX_PUD_10M B43_PHY_N(0x208) /* AFE seq rx2tx power up/down delay 10M */
  694. #define B43_NPHY_AFESEQ_TX2RX_PUD_10M B43_PHY_N(0x209) /* AFE seq tx2rx power up/down delay 10M */
  695. #define B43_NPHY_DSSSCCK_CRSEXTL B43_PHY_N(0x20A) /* DSSS/CCK CRS extension length */
  696. #define B43_NPHY_ML_LOGSS_RATSLOPE B43_PHY_N(0x20B) /* ML/logss ratio slope */
  697. #define B43_NPHY_RIFS_SRCTL B43_PHY_N(0x20C) /* RIFS search timeout length */
  698. #define B43_NPHY_TXREALFD B43_PHY_N(0x20D) /* TX real frame delay */
  699. #define B43_NPHY_HPANT_SWTHRES B43_PHY_N(0x20E) /* High power antenna switch threshold */
  700. #define B43_NPHY_EDCRS_ASSTHRES0 B43_PHY_N(0x210) /* ED CRS assert threshold 0 */
  701. #define B43_NPHY_EDCRS_ASSTHRES1 B43_PHY_N(0x211) /* ED CRS assert threshold 1 */
  702. #define B43_NPHY_EDCRS_DEASSTHRES0 B43_PHY_N(0x212) /* ED CRS deassert threshold 0 */
  703. #define B43_NPHY_EDCRS_DEASSTHRES1 B43_PHY_N(0x213) /* ED CRS deassert threshold 1 */
  704. #define B43_NPHY_STR_WTIME20U B43_PHY_N(0x214) /* STR wait time 20U */
  705. #define B43_NPHY_STR_WTIME20L B43_PHY_N(0x215) /* STR wait time 20L */
  706. #define B43_NPHY_TONE_MIDX657M B43_PHY_N(0x216) /* Tone map index 657M */
  707. #define B43_NPHY_HTSIGTONES B43_PHY_N(0x217) /* HT signal tones */
  708. #define B43_NPHY_RSSI1 B43_PHY_N(0x219) /* RSSI value 1 */
  709. #define B43_NPHY_RSSI2 B43_PHY_N(0x21A) /* RSSI value 2 */
  710. #define B43_NPHY_CHAN_ESTHANG B43_PHY_N(0x21D) /* Channel estimate hang */
  711. #define B43_NPHY_FINERX2_CGC B43_PHY_N(0x221) /* Fine RX 2 clock gate control */
  712. #define B43_NPHY_FINERX2_CGC_DECGC 0x0008 /* Decode gated clocks */
  713. #define B43_NPHY_TXPCTL_INIT B43_PHY_N(0x222) /* TX power control init */
  714. #define B43_NPHY_TXPCTL_INIT_PIDXI1 0x00FF /* Power index init 1 */
  715. #define B43_NPHY_TXPCTL_INIT_PIDXI1_SHIFT 0
  716. #define B43_NPHY_ED_CRSEN B43_PHY_N(0x223)
  717. #define B43_NPHY_ED_CRS40ASSERTTHRESH0 B43_PHY_N(0x224)
  718. #define B43_NPHY_ED_CRS40ASSERTTHRESH1 B43_PHY_N(0x225)
  719. #define B43_NPHY_ED_CRS40DEASSERTTHRESH0 B43_PHY_N(0x226)
  720. #define B43_NPHY_ED_CRS40DEASSERTTHRESH1 B43_PHY_N(0x227)
  721. #define B43_NPHY_ED_CRS20LASSERTTHRESH0 B43_PHY_N(0x228)
  722. #define B43_NPHY_ED_CRS20LASSERTTHRESH1 B43_PHY_N(0x229)
  723. #define B43_NPHY_ED_CRS20LDEASSERTTHRESH0 B43_PHY_N(0x22A)
  724. #define B43_NPHY_ED_CRS20LDEASSERTTHRESH1 B43_PHY_N(0x22B)
  725. #define B43_NPHY_ED_CRS20UASSERTTHRESH0 B43_PHY_N(0x22C)
  726. #define B43_NPHY_ED_CRS20UASSERTTHRESH1 B43_PHY_N(0x22D)
  727. #define B43_NPHY_ED_CRS20UDEASSERTTHRESH0 B43_PHY_N(0x22E)
  728. #define B43_NPHY_ED_CRS20UDEASSERTTHRESH1 B43_PHY_N(0x22F)
  729. #define B43_NPHY_ED_CRS B43_PHY_N(0x230)
  730. #define B43_NPHY_TIMEOUTEN B43_PHY_N(0x231)
  731. #define B43_NPHY_OFDMPAYDECODETIMEOUTLEN B43_PHY_N(0x232)
  732. #define B43_NPHY_CCKPAYDECODETIMEOUTLEN B43_PHY_N(0x233)
  733. #define B43_NPHY_NONPAYDECODETIMEOUTLEN B43_PHY_N(0x234)
  734. #define B43_NPHY_TIMEOUTSTATUS B43_PHY_N(0x235)
  735. #define B43_NPHY_RFCTRLCORE0GPIO0 B43_PHY_N(0x236)
  736. #define B43_NPHY_RFCTRLCORE0GPIO1 B43_PHY_N(0x237)
  737. #define B43_NPHY_RFCTRLCORE0GPIO2 B43_PHY_N(0x238)
  738. #define B43_NPHY_RFCTRLCORE0GPIO3 B43_PHY_N(0x239)
  739. #define B43_NPHY_RFCTRLCORE1GPIO0 B43_PHY_N(0x23A)
  740. #define B43_NPHY_RFCTRLCORE1GPIO1 B43_PHY_N(0x23B)
  741. #define B43_NPHY_RFCTRLCORE1GPIO2 B43_PHY_N(0x23C)
  742. #define B43_NPHY_RFCTRLCORE1GPIO3 B43_PHY_N(0x23D)
  743. #define B43_NPHY_BPHYTESTCONTROL B43_PHY_N(0x23E)
  744. /* REV3+ */
  745. #define B43_NPHY_FORCEFRONT0 B43_PHY_N(0x23F)
  746. #define B43_NPHY_FORCEFRONT1 B43_PHY_N(0x240)
  747. #define B43_NPHY_NORMVARHYSTTH B43_PHY_N(0x241)
  748. #define B43_NPHY_TXCCKERROR B43_PHY_N(0x242)
  749. #define B43_NPHY_AFESEQINITDACGAIN B43_PHY_N(0x243)
  750. #define B43_NPHY_TXANTSWLUT B43_PHY_N(0x244)
  751. #define B43_NPHY_CORECONFIG B43_PHY_N(0x245)
  752. #define B43_NPHY_ANTENNADIVDWELLTIME B43_PHY_N(0x246)
  753. #define B43_NPHY_ANTENNACCKDIVDWELLTIME B43_PHY_N(0x247)
  754. #define B43_NPHY_ANTENNADIVBACKOFFGAIN B43_PHY_N(0x248)
  755. #define B43_NPHY_ANTENNADIVMINGAIN B43_PHY_N(0x249)
  756. #define B43_NPHY_BRDSEL_NORMVARHYSTTH B43_PHY_N(0x24A)
  757. #define B43_NPHY_RXANTSWITCHCTRL B43_PHY_N(0x24B)
  758. #define B43_NPHY_ENERGYDROPTIMEOUTLEN2 B43_PHY_N(0x24C)
  759. #define B43_NPHY_ML_LOG_TXEVM0 B43_PHY_N(0x250)
  760. #define B43_NPHY_ML_LOG_TXEVM1 B43_PHY_N(0x251)
  761. #define B43_NPHY_ML_LOG_TXEVM2 B43_PHY_N(0x252)
  762. #define B43_NPHY_ML_LOG_TXEVM3 B43_PHY_N(0x253)
  763. #define B43_NPHY_ML_LOG_TXEVM4 B43_PHY_N(0x254)
  764. #define B43_NPHY_ML_LOG_TXEVM5 B43_PHY_N(0x255)
  765. #define B43_NPHY_ML_LOG_TXEVM6 B43_PHY_N(0x256)
  766. #define B43_NPHY_ML_LOG_TXEVM7 B43_PHY_N(0x257)
  767. #define B43_NPHY_ML_SCALE_TWEAK B43_PHY_N(0x258)
  768. #define B43_NPHY_MLUA B43_PHY_N(0x259)
  769. #define B43_NPHY_ZFUA B43_PHY_N(0x25A)
  770. #define B43_NPHY_CHANUPSYM01 B43_PHY_N(0x25B)
  771. #define B43_NPHY_CHANUPSYM2 B43_PHY_N(0x25C)
  772. #define B43_NPHY_RXSTRNFILT20NUM00 B43_PHY_N(0x25D)
  773. #define B43_NPHY_RXSTRNFILT20NUM01 B43_PHY_N(0x25E)
  774. #define B43_NPHY_RXSTRNFILT20NUM02 B43_PHY_N(0x25F)
  775. #define B43_NPHY_RXSTRNFILT20DEN00 B43_PHY_N(0x260)
  776. #define B43_NPHY_RXSTRNFILT20DEN01 B43_PHY_N(0x261)
  777. #define B43_NPHY_RXSTRNFILT20NUM10 B43_PHY_N(0x262)
  778. #define B43_NPHY_RXSTRNFILT20NUM11 B43_PHY_N(0x263)
  779. #define B43_NPHY_RXSTRNFILT20NUM12 B43_PHY_N(0x264)
  780. #define B43_NPHY_RXSTRNFILT20DEN10 B43_PHY_N(0x265)
  781. #define B43_NPHY_RXSTRNFILT20DEN11 B43_PHY_N(0x266)
  782. #define B43_NPHY_RXSTRNFILT40NUM00 B43_PHY_N(0x267)
  783. #define B43_NPHY_RXSTRNFILT40NUM01 B43_PHY_N(0x268)
  784. #define B43_NPHY_RXSTRNFILT40NUM02 B43_PHY_N(0x269)
  785. #define B43_NPHY_RXSTRNFILT40DEN00 B43_PHY_N(0x26A)
  786. #define B43_NPHY_RXSTRNFILT40DEN01 B43_PHY_N(0x26B)
  787. #define B43_NPHY_RXSTRNFILT40NUM10 B43_PHY_N(0x26C)
  788. #define B43_NPHY_RXSTRNFILT40NUM11 B43_PHY_N(0x26D)
  789. #define B43_NPHY_RXSTRNFILT40NUM12 B43_PHY_N(0x26E)
  790. #define B43_NPHY_RXSTRNFILT40DEN10 B43_PHY_N(0x26F)
  791. #define B43_NPHY_RXSTRNFILT40DEN11 B43_PHY_N(0x270)
  792. #define B43_NPHY_CRSHIGHPOWTHRESHOLD1 B43_PHY_N(0x271)
  793. #define B43_NPHY_CRSHIGHPOWTHRESHOLD2 B43_PHY_N(0x272)
  794. #define B43_NPHY_CRSHIGHLOWPOWTHRESHOLD B43_PHY_N(0x273)
  795. #define B43_NPHY_CRSHIGHPOWTHRESHOLD1L B43_PHY_N(0x274)
  796. #define B43_NPHY_CRSHIGHPOWTHRESHOLD2L B43_PHY_N(0x275)
  797. #define B43_NPHY_CRSHIGHLOWPOWTHRESHOLDL B43_PHY_N(0x276)
  798. #define B43_NPHY_CRSHIGHPOWTHRESHOLD1U B43_PHY_N(0x277)
  799. #define B43_NPHY_CRSHIGHPOWTHRESHOLD2U B43_PHY_N(0x278)
  800. #define B43_NPHY_CRSHIGHLOWPOWTHRESHOLDU B43_PHY_N(0x279)
  801. #define B43_NPHY_CRSACIDETECTTHRESH B43_PHY_N(0x27A)
  802. #define B43_NPHY_CRSACIDETECTTHRESHL B43_PHY_N(0x27B)
  803. #define B43_NPHY_CRSACIDETECTTHRESHU B43_PHY_N(0x27C)
  804. #define B43_NPHY_CRSMINPOWER0 B43_PHY_N(0x27D)
  805. #define B43_NPHY_CRSMINPOWER1 B43_PHY_N(0x27E)
  806. #define B43_NPHY_CRSMINPOWER2 B43_PHY_N(0x27F)
  807. #define B43_NPHY_CRSMINPOWERL0 B43_PHY_N(0x280)
  808. #define B43_NPHY_CRSMINPOWERL1 B43_PHY_N(0x281)
  809. #define B43_NPHY_CRSMINPOWERL2 B43_PHY_N(0x282)
  810. #define B43_NPHY_CRSMINPOWERU0 B43_PHY_N(0x283)
  811. #define B43_NPHY_CRSMINPOWERU1 B43_PHY_N(0x284)
  812. #define B43_NPHY_CRSMINPOWERU2 B43_PHY_N(0x285)
  813. #define B43_NPHY_STRPARAM B43_PHY_N(0x286)
  814. #define B43_NPHY_STRPARAML B43_PHY_N(0x287)
  815. #define B43_NPHY_STRPARAMU B43_PHY_N(0x288)
  816. #define B43_NPHY_BPHYCRSMINPOWER0 B43_PHY_N(0x289)
  817. #define B43_NPHY_BPHYCRSMINPOWER1 B43_PHY_N(0x28A)
  818. #define B43_NPHY_BPHYCRSMINPOWER2 B43_PHY_N(0x28B)
  819. #define B43_NPHY_BPHYFILTDEN0COEF B43_PHY_N(0x28C)
  820. #define B43_NPHY_BPHYFILTDEN1COEF B43_PHY_N(0x28D)
  821. #define B43_NPHY_BPHYFILTDEN2COEF B43_PHY_N(0x28E)
  822. #define B43_NPHY_BPHYFILTNUM0COEF B43_PHY_N(0x28F)
  823. #define B43_NPHY_BPHYFILTNUM1COEF B43_PHY_N(0x290)
  824. #define B43_NPHY_BPHYFILTNUM2COEF B43_PHY_N(0x291)
  825. #define B43_NPHY_BPHYFILTNUM01COEF2 B43_PHY_N(0x292)
  826. #define B43_NPHY_BPHYFILTBYPASS B43_PHY_N(0x293)
  827. #define B43_NPHY_SGILTRNOFFSET B43_PHY_N(0x294)
  828. #define B43_NPHY_RADAR_T2_MIN B43_PHY_N(0x295)
  829. #define B43_NPHY_TXPWRCTRLDAMPING B43_PHY_N(0x296)
  830. #define B43_NPHY_PAPD_EN0 B43_PHY_N(0x297) /* PAPD Enable0 TBD */
  831. #define B43_NPHY_EPS_TABLE_ADJ0 B43_PHY_N(0x298) /* EPS Table Adj0 TBD */
  832. #define B43_NPHY_EPS_OVERRIDEI_0 B43_PHY_N(0x299)
  833. #define B43_NPHY_EPS_OVERRIDEQ_0 B43_PHY_N(0x29A)
  834. #define B43_NPHY_PAPD_EN1 B43_PHY_N(0x29B) /* PAPD Enable1 TBD */
  835. #define B43_NPHY_EPS_TABLE_ADJ1 B43_PHY_N(0x29C) /* EPS Table Adj1 TBD */
  836. #define B43_NPHY_EPS_OVERRIDEI_1 B43_PHY_N(0x29D)
  837. #define B43_NPHY_EPS_OVERRIDEQ_1 B43_PHY_N(0x29E)
  838. #define B43_NPHY_PAPD_CAL_ADDRESS B43_PHY_N(0x29F)
  839. #define B43_NPHY_PAPD_CAL_YREFEPSILON B43_PHY_N(0x2A0)
  840. #define B43_NPHY_PAPD_CAL_SETTLE B43_PHY_N(0x2A1)
  841. #define B43_NPHY_PAPD_CAL_CORRELATE B43_PHY_N(0x2A2)
  842. #define B43_NPHY_PAPD_CAL_SHIFTS0 B43_PHY_N(0x2A3)
  843. #define B43_NPHY_PAPD_CAL_SHIFTS1 B43_PHY_N(0x2A4)
  844. #define B43_NPHY_SAMPLE_START_ADDR B43_PHY_N(0x2A5)
  845. #define B43_NPHY_RADAR_ADC_TO_DBM B43_PHY_N(0x2A6)
  846. #define B43_NPHY_REV3_C2_INITGAIN_A B43_PHY_N(0x2A7)
  847. #define B43_NPHY_REV3_C2_INITGAIN_B B43_PHY_N(0x2A8)
  848. #define B43_NPHY_REV3_C2_CLIP_HIGAIN_A B43_PHY_N(0x2A9)
  849. #define B43_NPHY_REV3_C2_CLIP_HIGAIN_B B43_PHY_N(0x2AA)
  850. #define B43_NPHY_REV3_C2_CLIP_MEDGAIN_A B43_PHY_N(0x2AB)
  851. #define B43_NPHY_REV3_C2_CLIP_MEDGAIN_B B43_PHY_N(0x2AC)
  852. #define B43_NPHY_REV3_C2_CLIP_LOGAIN_A B43_PHY_N(0x2AD)
  853. #define B43_NPHY_REV3_C2_CLIP_LOGAIN_B B43_PHY_N(0x2AE)
  854. #define B43_NPHY_REV3_C2_CLIP2_GAIN_A B43_PHY_N(0x2AF)
  855. #define B43_NPHY_REV3_C2_CLIP2_GAIN_B B43_PHY_N(0x2B0)
  856. #define B43_NPHY_REV7_RF_CTL_MISC_REG3 B43_PHY_N(0x340)
  857. #define B43_NPHY_REV7_RF_CTL_MISC_REG4 B43_PHY_N(0x341)
  858. #define B43_NPHY_REV7_RF_CTL_OVER3 B43_PHY_N(0x342)
  859. #define B43_NPHY_REV7_RF_CTL_OVER4 B43_PHY_N(0x343)
  860. #define B43_NPHY_REV7_RF_CTL_MISC_REG5 B43_PHY_N(0x344)
  861. #define B43_NPHY_REV7_RF_CTL_MISC_REG6 B43_PHY_N(0x345)
  862. #define B43_NPHY_REV7_RF_CTL_OVER5 B43_PHY_N(0x346)
  863. #define B43_NPHY_REV7_RF_CTL_OVER6 B43_PHY_N(0x347)
  864. #define B43_PHY_B_BBCFG B43_PHY_N_BMODE(0x001) /* BB config */
  865. #define B43_PHY_B_BBCFG_RSTCCA 0x4000 /* Reset CCA */
  866. #define B43_PHY_B_BBCFG_RSTRX 0x8000 /* Reset RX */
  867. #define B43_PHY_B_TEST B43_PHY_N_BMODE(0x00A)
  868. struct b43_wldev;
  869. enum b43_nphy_spur_avoid {
  870. B43_SPUR_AVOID_DISABLE,
  871. B43_SPUR_AVOID_AUTO,
  872. B43_SPUR_AVOID_FORCE,
  873. };
  874. struct b43_chanspec {
  875. u16 center_freq;
  876. enum nl80211_channel_type channel_type;
  877. };
  878. struct b43_phy_n_iq_comp {
  879. s16 a0;
  880. s16 b0;
  881. s16 a1;
  882. s16 b1;
  883. };
  884. struct b43_phy_n_rssical_cache {
  885. u16 rssical_radio_regs_2G[2];
  886. u16 rssical_phy_regs_2G[12];
  887. u16 rssical_radio_regs_5G[2];
  888. u16 rssical_phy_regs_5G[12];
  889. };
  890. struct b43_phy_n_cal_cache {
  891. u16 txcal_radio_regs_2G[8];
  892. u16 txcal_coeffs_2G[8];
  893. struct b43_phy_n_iq_comp rxcal_coeffs_2G;
  894. u16 txcal_radio_regs_5G[8];
  895. u16 txcal_coeffs_5G[8];
  896. struct b43_phy_n_iq_comp rxcal_coeffs_5G;
  897. };
  898. struct b43_phy_n_txpwrindex {
  899. s8 index;
  900. s8 index_internal;
  901. s8 index_internal_save;
  902. u16 AfectrlOverride;
  903. u16 AfeCtrlDacGain;
  904. u16 rad_gain;
  905. u8 bbmult;
  906. u16 iqcomp_a;
  907. u16 iqcomp_b;
  908. u16 locomp;
  909. };
  910. struct b43_phy_n_pwr_ctl_info {
  911. u8 idle_tssi_2g;
  912. u8 idle_tssi_5g;
  913. };
  914. struct b43_phy_n {
  915. u8 antsel_type;
  916. u8 cal_orig_pwr_idx[2];
  917. u8 measure_hold;
  918. u8 phyrxchain;
  919. u8 hw_phyrxchain;
  920. u8 hw_phytxchain;
  921. u8 perical;
  922. u32 deaf_count;
  923. u32 rxcalparams;
  924. bool hang_avoid;
  925. bool mute;
  926. u16 papd_epsilon_offset[2];
  927. s32 preamble_override;
  928. u32 bb_mult_save;
  929. bool gain_boost;
  930. bool elna_gain_config;
  931. bool band5g_pwrgain;
  932. bool use_int_tx_iq_lo_cal;
  933. bool lpf_bw_overrode_for_sample_play;
  934. u8 mphase_cal_phase_id;
  935. u16 mphase_txcal_cmdidx;
  936. u16 mphase_txcal_numcmds;
  937. u16 mphase_txcal_bestcoeffs[11];
  938. bool txpwrctrl;
  939. bool pwg_gain_5ghz;
  940. u8 tx_pwr_idx[2];
  941. s8 tx_power_offset[101];
  942. u16 adj_pwr_tbl[84];
  943. u16 txcal_bbmult;
  944. u16 txiqlocal_bestc[11];
  945. bool txiqlocal_coeffsvalid;
  946. struct b43_phy_n_txpwrindex txpwrindex[2];
  947. struct b43_phy_n_pwr_ctl_info pwr_ctl_info[2];
  948. struct b43_chanspec txiqlocal_chanspec;
  949. struct b43_ppr tx_pwr_max_ppr;
  950. u16 tx_pwr_last_recalc_freq;
  951. int tx_pwr_last_recalc_limit;
  952. u8 txrx_chain;
  953. u16 tx_rx_cal_phy_saveregs[11];
  954. u16 tx_rx_cal_radio_saveregs[22];
  955. u16 rfctrl_intc1_save;
  956. u16 rfctrl_intc2_save;
  957. u16 classifier_state;
  958. u16 clip_state[2];
  959. enum b43_nphy_spur_avoid spur_avoid;
  960. bool aband_spurwar_en;
  961. bool gband_spurwar_en;
  962. bool ipa2g_on;
  963. struct b43_chanspec iqcal_chanspec_2G;
  964. struct b43_chanspec rssical_chanspec_2G;
  965. bool ipa5g_on;
  966. struct b43_chanspec iqcal_chanspec_5G;
  967. struct b43_chanspec rssical_chanspec_5G;
  968. struct b43_phy_n_rssical_cache rssical_cache;
  969. struct b43_phy_n_cal_cache cal_cache;
  970. bool crsminpwr_adjusted;
  971. bool noisevars_adjusted;
  972. };
  973. struct b43_phy_operations;
  974. extern const struct b43_phy_operations b43_phyops_n;
  975. #endif /* B43_NPHY_H_ */