hw.c 72 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569
  1. /******************************************************************************
  2. *
  3. * Copyright(c) 2009-2014 Realtek Corporation.
  4. *
  5. * This program is free software; you can redistribute it and/or modify it
  6. * under the terms of version 2 of the GNU General Public License as
  7. * published by the Free Software Foundation.
  8. *
  9. * This program is distributed in the hope that it will be useful, but WITHOUT
  10. * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  11. * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  12. * more details.
  13. *
  14. * The full GNU General Public License is included in this distribution in the
  15. * file called LICENSE.
  16. *
  17. * Contact Information:
  18. * wlanfae <wlanfae@realtek.com>
  19. * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
  20. * Hsinchu 300, Taiwan.
  21. *
  22. * Larry Finger <Larry.Finger@lwfinger.net>
  23. *
  24. *****************************************************************************/
  25. #include "../wifi.h"
  26. #include "../efuse.h"
  27. #include "../base.h"
  28. #include "../regd.h"
  29. #include "../cam.h"
  30. #include "../ps.h"
  31. #include "../pci.h"
  32. #include "reg.h"
  33. #include "def.h"
  34. #include "phy.h"
  35. #include "dm.h"
  36. #include "fw.h"
  37. #include "led.h"
  38. #include "hw.h"
  39. #include "../pwrseqcmd.h"
  40. #include "pwrseq.h"
  41. #define LLT_CONFIG 5
  42. static void _rtl92ee_set_bcn_ctrl_reg(struct ieee80211_hw *hw,
  43. u8 set_bits, u8 clear_bits)
  44. {
  45. struct rtl_pci *rtlpci = rtl_pcidev(rtl_pcipriv(hw));
  46. struct rtl_priv *rtlpriv = rtl_priv(hw);
  47. rtlpci->reg_bcn_ctrl_val |= set_bits;
  48. rtlpci->reg_bcn_ctrl_val &= ~clear_bits;
  49. rtl_write_byte(rtlpriv, REG_BCN_CTRL, (u8)rtlpci->reg_bcn_ctrl_val);
  50. }
  51. static void _rtl92ee_stop_tx_beacon(struct ieee80211_hw *hw)
  52. {
  53. struct rtl_priv *rtlpriv = rtl_priv(hw);
  54. u8 tmp;
  55. tmp = rtl_read_byte(rtlpriv, REG_FWHW_TXQ_CTRL + 2);
  56. rtl_write_byte(rtlpriv, REG_FWHW_TXQ_CTRL + 2, tmp & (~BIT(6)));
  57. rtl_write_byte(rtlpriv, REG_TBTT_PROHIBIT + 1, 0x64);
  58. tmp = rtl_read_byte(rtlpriv, REG_TBTT_PROHIBIT + 2);
  59. tmp &= ~(BIT(0));
  60. rtl_write_byte(rtlpriv, REG_TBTT_PROHIBIT + 2, tmp);
  61. }
  62. static void _rtl92ee_resume_tx_beacon(struct ieee80211_hw *hw)
  63. {
  64. struct rtl_priv *rtlpriv = rtl_priv(hw);
  65. u8 tmp;
  66. tmp = rtl_read_byte(rtlpriv, REG_FWHW_TXQ_CTRL + 2);
  67. rtl_write_byte(rtlpriv, REG_FWHW_TXQ_CTRL + 2, tmp | BIT(6));
  68. rtl_write_byte(rtlpriv, REG_TBTT_PROHIBIT + 1, 0xff);
  69. tmp = rtl_read_byte(rtlpriv, REG_TBTT_PROHIBIT + 2);
  70. tmp |= BIT(0);
  71. rtl_write_byte(rtlpriv, REG_TBTT_PROHIBIT + 2, tmp);
  72. }
  73. static void _rtl92ee_enable_bcn_sub_func(struct ieee80211_hw *hw)
  74. {
  75. _rtl92ee_set_bcn_ctrl_reg(hw, 0, BIT(1));
  76. }
  77. static void _rtl92ee_return_beacon_queue_skb(struct ieee80211_hw *hw)
  78. {
  79. struct rtl_priv *rtlpriv = rtl_priv(hw);
  80. struct rtl_pci *rtlpci = rtl_pcidev(rtl_pcipriv(hw));
  81. struct rtl8192_tx_ring *ring = &rtlpci->tx_ring[BEACON_QUEUE];
  82. unsigned long flags;
  83. spin_lock_irqsave(&rtlpriv->locks.irq_th_lock, flags);
  84. while (skb_queue_len(&ring->queue)) {
  85. struct rtl_tx_buffer_desc *entry =
  86. &ring->buffer_desc[ring->idx];
  87. struct sk_buff *skb = __skb_dequeue(&ring->queue);
  88. pci_unmap_single(rtlpci->pdev,
  89. rtlpriv->cfg->ops->get_desc(
  90. (u8 *)entry, true, HW_DESC_TXBUFF_ADDR),
  91. skb->len, PCI_DMA_TODEVICE);
  92. kfree_skb(skb);
  93. ring->idx = (ring->idx + 1) % ring->entries;
  94. }
  95. spin_unlock_irqrestore(&rtlpriv->locks.irq_th_lock, flags);
  96. }
  97. static void _rtl92ee_disable_bcn_sub_func(struct ieee80211_hw *hw)
  98. {
  99. _rtl92ee_set_bcn_ctrl_reg(hw, BIT(1), 0);
  100. }
  101. static void _rtl92ee_set_fw_clock_on(struct ieee80211_hw *hw,
  102. u8 rpwm_val, bool b_need_turn_off_ckk)
  103. {
  104. struct rtl_priv *rtlpriv = rtl_priv(hw);
  105. struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw));
  106. bool b_support_remote_wake_up;
  107. u32 count = 0, isr_regaddr, content;
  108. bool b_schedule_timer = b_need_turn_off_ckk;
  109. rtlpriv->cfg->ops->get_hw_reg(hw, HAL_DEF_WOWLAN,
  110. (u8 *)(&b_support_remote_wake_up));
  111. if (!rtlhal->fw_ready)
  112. return;
  113. if (!rtlpriv->psc.fw_current_inpsmode)
  114. return;
  115. while (1) {
  116. spin_lock_bh(&rtlpriv->locks.fw_ps_lock);
  117. if (rtlhal->fw_clk_change_in_progress) {
  118. while (rtlhal->fw_clk_change_in_progress) {
  119. spin_unlock_bh(&rtlpriv->locks.fw_ps_lock);
  120. count++;
  121. udelay(100);
  122. if (count > 1000)
  123. return;
  124. spin_lock_bh(&rtlpriv->locks.fw_ps_lock);
  125. }
  126. spin_unlock_bh(&rtlpriv->locks.fw_ps_lock);
  127. } else {
  128. rtlhal->fw_clk_change_in_progress = false;
  129. spin_unlock_bh(&rtlpriv->locks.fw_ps_lock);
  130. break;
  131. }
  132. }
  133. if (IS_IN_LOW_POWER_STATE_92E(rtlhal->fw_ps_state)) {
  134. rtlpriv->cfg->ops->get_hw_reg(hw, HW_VAR_SET_RPWM,
  135. (u8 *)(&rpwm_val));
  136. if (FW_PS_IS_ACK(rpwm_val)) {
  137. isr_regaddr = REG_HISR;
  138. content = rtl_read_dword(rtlpriv, isr_regaddr);
  139. while (!(content & IMR_CPWM) && (count < 500)) {
  140. udelay(50);
  141. count++;
  142. content = rtl_read_dword(rtlpriv, isr_regaddr);
  143. }
  144. if (content & IMR_CPWM) {
  145. rtl_write_word(rtlpriv, isr_regaddr, 0x0100);
  146. rtlhal->fw_ps_state = FW_PS_STATE_RF_ON_92E;
  147. RT_TRACE(rtlpriv, COMP_POWER, DBG_LOUD,
  148. "Receive CPWM INT!!! PSState = %X\n",
  149. rtlhal->fw_ps_state);
  150. }
  151. }
  152. spin_lock_bh(&rtlpriv->locks.fw_ps_lock);
  153. rtlhal->fw_clk_change_in_progress = false;
  154. spin_unlock_bh(&rtlpriv->locks.fw_ps_lock);
  155. if (b_schedule_timer) {
  156. mod_timer(&rtlpriv->works.fw_clockoff_timer,
  157. jiffies + MSECS(10));
  158. }
  159. } else {
  160. spin_lock_bh(&rtlpriv->locks.fw_ps_lock);
  161. rtlhal->fw_clk_change_in_progress = false;
  162. spin_unlock_bh(&rtlpriv->locks.fw_ps_lock);
  163. }
  164. }
  165. static void _rtl92ee_set_fw_clock_off(struct ieee80211_hw *hw, u8 rpwm_val)
  166. {
  167. struct rtl_priv *rtlpriv = rtl_priv(hw);
  168. struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw));
  169. struct rtl_pci *rtlpci = rtl_pcidev(rtl_pcipriv(hw));
  170. struct rtl8192_tx_ring *ring;
  171. enum rf_pwrstate rtstate;
  172. bool b_schedule_timer = false;
  173. u8 queue;
  174. if (!rtlhal->fw_ready)
  175. return;
  176. if (!rtlpriv->psc.fw_current_inpsmode)
  177. return;
  178. if (!rtlhal->allow_sw_to_change_hwclc)
  179. return;
  180. rtlpriv->cfg->ops->get_hw_reg(hw, HW_VAR_RF_STATE, (u8 *)(&rtstate));
  181. if (rtstate == ERFOFF || rtlpriv->psc.inactive_pwrstate == ERFOFF)
  182. return;
  183. for (queue = 0; queue < RTL_PCI_MAX_TX_QUEUE_COUNT; queue++) {
  184. ring = &rtlpci->tx_ring[queue];
  185. if (skb_queue_len(&ring->queue)) {
  186. b_schedule_timer = true;
  187. break;
  188. }
  189. }
  190. if (b_schedule_timer) {
  191. mod_timer(&rtlpriv->works.fw_clockoff_timer,
  192. jiffies + MSECS(10));
  193. return;
  194. }
  195. if (FW_PS_STATE(rtlhal->fw_ps_state) != FW_PS_STATE_RF_OFF_LOW_PWR) {
  196. spin_lock_bh(&rtlpriv->locks.fw_ps_lock);
  197. if (!rtlhal->fw_clk_change_in_progress) {
  198. rtlhal->fw_clk_change_in_progress = true;
  199. spin_unlock_bh(&rtlpriv->locks.fw_ps_lock);
  200. rtlhal->fw_ps_state = FW_PS_STATE(rpwm_val);
  201. rtl_write_word(rtlpriv, REG_HISR, 0x0100);
  202. rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_SET_RPWM,
  203. (u8 *)(&rpwm_val));
  204. spin_lock_bh(&rtlpriv->locks.fw_ps_lock);
  205. rtlhal->fw_clk_change_in_progress = false;
  206. spin_unlock_bh(&rtlpriv->locks.fw_ps_lock);
  207. } else {
  208. spin_unlock_bh(&rtlpriv->locks.fw_ps_lock);
  209. mod_timer(&rtlpriv->works.fw_clockoff_timer,
  210. jiffies + MSECS(10));
  211. }
  212. }
  213. }
  214. static void _rtl92ee_set_fw_ps_rf_on(struct ieee80211_hw *hw)
  215. {
  216. u8 rpwm_val = 0;
  217. rpwm_val |= (FW_PS_STATE_RF_OFF_92E | FW_PS_ACK);
  218. _rtl92ee_set_fw_clock_on(hw, rpwm_val, true);
  219. }
  220. static void _rtl92ee_set_fw_ps_rf_off_low_power(struct ieee80211_hw *hw)
  221. {
  222. u8 rpwm_val = 0;
  223. rpwm_val |= FW_PS_STATE_RF_OFF_LOW_PWR;
  224. _rtl92ee_set_fw_clock_off(hw, rpwm_val);
  225. }
  226. void rtl92ee_fw_clk_off_timer_callback(unsigned long data)
  227. {
  228. struct ieee80211_hw *hw = (struct ieee80211_hw *)data;
  229. _rtl92ee_set_fw_ps_rf_off_low_power(hw);
  230. }
  231. static void _rtl92ee_fwlps_leave(struct ieee80211_hw *hw)
  232. {
  233. struct rtl_priv *rtlpriv = rtl_priv(hw);
  234. struct rtl_ps_ctl *ppsc = rtl_psc(rtl_priv(hw));
  235. struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw));
  236. bool fw_current_inps = false;
  237. u8 rpwm_val = 0, fw_pwrmode = FW_PS_ACTIVE_MODE;
  238. if (ppsc->low_power_enable) {
  239. rpwm_val = (FW_PS_STATE_ALL_ON_92E | FW_PS_ACK);/* RF on */
  240. _rtl92ee_set_fw_clock_on(hw, rpwm_val, false);
  241. rtlhal->allow_sw_to_change_hwclc = false;
  242. rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_H2C_FW_PWRMODE,
  243. (u8 *)(&fw_pwrmode));
  244. rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_FW_PSMODE_STATUS,
  245. (u8 *)(&fw_current_inps));
  246. } else {
  247. rpwm_val = FW_PS_STATE_ALL_ON_92E; /* RF on */
  248. rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_SET_RPWM,
  249. (u8 *)(&rpwm_val));
  250. rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_H2C_FW_PWRMODE,
  251. (u8 *)(&fw_pwrmode));
  252. rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_FW_PSMODE_STATUS,
  253. (u8 *)(&fw_current_inps));
  254. }
  255. }
  256. static void _rtl92ee_fwlps_enter(struct ieee80211_hw *hw)
  257. {
  258. struct rtl_priv *rtlpriv = rtl_priv(hw);
  259. struct rtl_ps_ctl *ppsc = rtl_psc(rtl_priv(hw));
  260. struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw));
  261. bool fw_current_inps = true;
  262. u8 rpwm_val;
  263. if (ppsc->low_power_enable) {
  264. rpwm_val = FW_PS_STATE_RF_OFF_LOW_PWR; /* RF off */
  265. rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_FW_PSMODE_STATUS,
  266. (u8 *)(&fw_current_inps));
  267. rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_H2C_FW_PWRMODE,
  268. (u8 *)(&ppsc->fwctrl_psmode));
  269. rtlhal->allow_sw_to_change_hwclc = true;
  270. _rtl92ee_set_fw_clock_off(hw, rpwm_val);
  271. } else {
  272. rpwm_val = FW_PS_STATE_RF_OFF_92E; /* RF off */
  273. rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_FW_PSMODE_STATUS,
  274. (u8 *)(&fw_current_inps));
  275. rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_H2C_FW_PWRMODE,
  276. (u8 *)(&ppsc->fwctrl_psmode));
  277. rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_SET_RPWM,
  278. (u8 *)(&rpwm_val));
  279. }
  280. }
  281. void rtl92ee_get_hw_reg(struct ieee80211_hw *hw, u8 variable, u8 *val)
  282. {
  283. struct rtl_priv *rtlpriv = rtl_priv(hw);
  284. struct rtl_ps_ctl *ppsc = rtl_psc(rtl_priv(hw));
  285. struct rtl_pci *rtlpci = rtl_pcidev(rtl_pcipriv(hw));
  286. switch (variable) {
  287. case HW_VAR_RCR:
  288. *((u32 *)(val)) = rtlpci->receive_config;
  289. break;
  290. case HW_VAR_RF_STATE:
  291. *((enum rf_pwrstate *)(val)) = ppsc->rfpwr_state;
  292. break;
  293. case HW_VAR_FWLPS_RF_ON:{
  294. enum rf_pwrstate rfstate;
  295. u32 val_rcr;
  296. rtlpriv->cfg->ops->get_hw_reg(hw, HW_VAR_RF_STATE,
  297. (u8 *)(&rfstate));
  298. if (rfstate == ERFOFF) {
  299. *((bool *)(val)) = true;
  300. } else {
  301. val_rcr = rtl_read_dword(rtlpriv, REG_RCR);
  302. val_rcr &= 0x00070000;
  303. if (val_rcr)
  304. *((bool *)(val)) = false;
  305. else
  306. *((bool *)(val)) = true;
  307. }
  308. }
  309. break;
  310. case HW_VAR_FW_PSMODE_STATUS:
  311. *((bool *)(val)) = ppsc->fw_current_inpsmode;
  312. break;
  313. case HW_VAR_CORRECT_TSF:{
  314. u64 tsf;
  315. u32 *ptsf_low = (u32 *)&tsf;
  316. u32 *ptsf_high = ((u32 *)&tsf) + 1;
  317. *ptsf_high = rtl_read_dword(rtlpriv, (REG_TSFTR + 4));
  318. *ptsf_low = rtl_read_dword(rtlpriv, REG_TSFTR);
  319. *((u64 *)(val)) = tsf;
  320. }
  321. break;
  322. default:
  323. RT_TRACE(rtlpriv, COMP_ERR, DBG_DMESG,
  324. "switch case not process %x\n", variable);
  325. break;
  326. }
  327. }
  328. static void _rtl92ee_download_rsvd_page(struct ieee80211_hw *hw)
  329. {
  330. struct rtl_priv *rtlpriv = rtl_priv(hw);
  331. u8 tmp_regcr, tmp_reg422;
  332. u8 bcnvalid_reg, txbc_reg;
  333. u8 count = 0, dlbcn_count = 0;
  334. bool b_recover = false;
  335. /*Set REG_CR bit 8. DMA beacon by SW.*/
  336. tmp_regcr = rtl_read_byte(rtlpriv, REG_CR + 1);
  337. rtl_write_byte(rtlpriv, REG_CR + 1, tmp_regcr | BIT(0));
  338. /* Disable Hw protection for a time which revserd for Hw sending beacon.
  339. * Fix download reserved page packet fail
  340. * that access collision with the protection time.
  341. * 2010.05.11. Added by tynli.
  342. */
  343. _rtl92ee_set_bcn_ctrl_reg(hw, 0, BIT(3));
  344. _rtl92ee_set_bcn_ctrl_reg(hw, BIT(4), 0);
  345. /* Set FWHW_TXQ_CTRL 0x422[6]=0 to
  346. * tell Hw the packet is not a real beacon frame.
  347. */
  348. tmp_reg422 = rtl_read_byte(rtlpriv, REG_FWHW_TXQ_CTRL + 2);
  349. rtl_write_byte(rtlpriv, REG_FWHW_TXQ_CTRL + 2, tmp_reg422 & (~BIT(6)));
  350. if (tmp_reg422 & BIT(6))
  351. b_recover = true;
  352. do {
  353. /* Clear beacon valid check bit */
  354. bcnvalid_reg = rtl_read_byte(rtlpriv, REG_DWBCN0_CTRL + 2);
  355. rtl_write_byte(rtlpriv, REG_DWBCN0_CTRL + 2,
  356. bcnvalid_reg | BIT(0));
  357. /* Return Beacon TCB */
  358. _rtl92ee_return_beacon_queue_skb(hw);
  359. /* download rsvd page */
  360. rtl92ee_set_fw_rsvdpagepkt(hw, false);
  361. txbc_reg = rtl_read_byte(rtlpriv, REG_MGQ_TXBD_NUM + 3);
  362. count = 0;
  363. while ((txbc_reg & BIT(4)) && count < 20) {
  364. count++;
  365. udelay(10);
  366. txbc_reg = rtl_read_byte(rtlpriv, REG_MGQ_TXBD_NUM + 3);
  367. }
  368. rtl_write_byte(rtlpriv, REG_MGQ_TXBD_NUM + 3,
  369. txbc_reg | BIT(4));
  370. /* check rsvd page download OK. */
  371. bcnvalid_reg = rtl_read_byte(rtlpriv, REG_DWBCN0_CTRL + 2);
  372. count = 0;
  373. while (!(bcnvalid_reg & BIT(0)) && count < 20) {
  374. count++;
  375. udelay(50);
  376. bcnvalid_reg = rtl_read_byte(rtlpriv,
  377. REG_DWBCN0_CTRL + 2);
  378. }
  379. if (bcnvalid_reg & BIT(0))
  380. rtl_write_byte(rtlpriv, REG_DWBCN0_CTRL + 2, BIT(0));
  381. dlbcn_count++;
  382. } while (!(bcnvalid_reg & BIT(0)) && dlbcn_count < 5);
  383. if (!(bcnvalid_reg & BIT(0)))
  384. RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD,
  385. "Download RSVD page failed!\n");
  386. /* Enable Bcn */
  387. _rtl92ee_set_bcn_ctrl_reg(hw, BIT(3), 0);
  388. _rtl92ee_set_bcn_ctrl_reg(hw, 0, BIT(4));
  389. if (b_recover)
  390. rtl_write_byte(rtlpriv, REG_FWHW_TXQ_CTRL + 2, tmp_reg422);
  391. tmp_regcr = rtl_read_byte(rtlpriv, REG_CR + 1);
  392. rtl_write_byte(rtlpriv, REG_CR + 1, tmp_regcr & (~BIT(0)));
  393. }
  394. void rtl92ee_set_hw_reg(struct ieee80211_hw *hw, u8 variable, u8 *val)
  395. {
  396. struct rtl_priv *rtlpriv = rtl_priv(hw);
  397. struct rtl_pci *rtlpci = rtl_pcidev(rtl_pcipriv(hw));
  398. struct rtl_mac *mac = rtl_mac(rtl_priv(hw));
  399. struct rtl_efuse *efuse = rtl_efuse(rtl_priv(hw));
  400. struct rtl_ps_ctl *ppsc = rtl_psc(rtl_priv(hw));
  401. u8 idx;
  402. switch (variable) {
  403. case HW_VAR_ETHER_ADDR:
  404. for (idx = 0; idx < ETH_ALEN; idx++)
  405. rtl_write_byte(rtlpriv, (REG_MACID + idx), val[idx]);
  406. break;
  407. case HW_VAR_BASIC_RATE:{
  408. u16 b_rate_cfg = ((u16 *)val)[0];
  409. b_rate_cfg = b_rate_cfg & 0x15f;
  410. b_rate_cfg |= 0x01;
  411. b_rate_cfg = (b_rate_cfg | 0xd) & (~BIT(1));
  412. rtl_write_byte(rtlpriv, REG_RRSR, b_rate_cfg & 0xff);
  413. rtl_write_byte(rtlpriv, REG_RRSR + 1, (b_rate_cfg >> 8) & 0xff);
  414. break; }
  415. case HW_VAR_BSSID:
  416. for (idx = 0; idx < ETH_ALEN; idx++)
  417. rtl_write_byte(rtlpriv, (REG_BSSID + idx), val[idx]);
  418. break;
  419. case HW_VAR_SIFS:
  420. rtl_write_byte(rtlpriv, REG_SIFS_CTX + 1, val[0]);
  421. rtl_write_byte(rtlpriv, REG_SIFS_TRX + 1, val[1]);
  422. rtl_write_byte(rtlpriv, REG_SPEC_SIFS + 1, val[0]);
  423. rtl_write_byte(rtlpriv, REG_MAC_SPEC_SIFS + 1, val[0]);
  424. if (!mac->ht_enable)
  425. rtl_write_word(rtlpriv, REG_RESP_SIFS_OFDM, 0x0e0e);
  426. else
  427. rtl_write_word(rtlpriv, REG_RESP_SIFS_OFDM,
  428. *((u16 *)val));
  429. break;
  430. case HW_VAR_SLOT_TIME:{
  431. u8 e_aci;
  432. RT_TRACE(rtlpriv, COMP_MLME, DBG_TRACE,
  433. "HW_VAR_SLOT_TIME %x\n", val[0]);
  434. rtl_write_byte(rtlpriv, REG_SLOT, val[0]);
  435. for (e_aci = 0; e_aci < AC_MAX; e_aci++) {
  436. rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_AC_PARAM,
  437. (u8 *)(&e_aci));
  438. }
  439. break; }
  440. case HW_VAR_ACK_PREAMBLE:{
  441. u8 reg_tmp;
  442. u8 short_preamble = (bool)(*(u8 *)val);
  443. reg_tmp = (rtlpriv->mac80211.cur_40_prime_sc) << 5;
  444. if (short_preamble)
  445. reg_tmp |= 0x80;
  446. rtl_write_byte(rtlpriv, REG_RRSR + 2, reg_tmp);
  447. rtlpriv->mac80211.short_preamble = short_preamble;
  448. }
  449. break;
  450. case HW_VAR_WPA_CONFIG:
  451. rtl_write_byte(rtlpriv, REG_SECCFG, *((u8 *)val));
  452. break;
  453. case HW_VAR_AMPDU_FACTOR:{
  454. u8 regtoset_normal[4] = { 0x41, 0xa8, 0x72, 0xb9 };
  455. u8 fac;
  456. u8 *reg = NULL;
  457. u8 i = 0;
  458. reg = regtoset_normal;
  459. fac = *((u8 *)val);
  460. if (fac <= 3) {
  461. fac = (1 << (fac + 2));
  462. if (fac > 0xf)
  463. fac = 0xf;
  464. for (i = 0; i < 4; i++) {
  465. if ((reg[i] & 0xf0) > (fac << 4))
  466. reg[i] = (reg[i] & 0x0f) |
  467. (fac << 4);
  468. if ((reg[i] & 0x0f) > fac)
  469. reg[i] = (reg[i] & 0xf0) | fac;
  470. rtl_write_byte(rtlpriv,
  471. (REG_AGGLEN_LMT + i),
  472. reg[i]);
  473. }
  474. RT_TRACE(rtlpriv, COMP_MLME, DBG_LOUD,
  475. "Set HW_VAR_AMPDU_FACTOR:%#x\n", fac);
  476. }
  477. }
  478. break;
  479. case HW_VAR_AC_PARAM:{
  480. u8 e_aci = *((u8 *)val);
  481. if (rtlpci->acm_method != EACMWAY2_SW)
  482. rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_ACM_CTRL,
  483. (u8 *)(&e_aci));
  484. }
  485. break;
  486. case HW_VAR_ACM_CTRL:{
  487. u8 e_aci = *((u8 *)val);
  488. union aci_aifsn *aifs = (union aci_aifsn *)(&mac->ac[0].aifs);
  489. u8 acm = aifs->f.acm;
  490. u8 acm_ctrl = rtl_read_byte(rtlpriv, REG_ACMHWCTRL);
  491. acm_ctrl = acm_ctrl | ((rtlpci->acm_method == 2) ? 0x0 : 0x1);
  492. if (acm) {
  493. switch (e_aci) {
  494. case AC0_BE:
  495. acm_ctrl |= ACMHW_BEQEN;
  496. break;
  497. case AC2_VI:
  498. acm_ctrl |= ACMHW_VIQEN;
  499. break;
  500. case AC3_VO:
  501. acm_ctrl |= ACMHW_VOQEN;
  502. break;
  503. default:
  504. RT_TRACE(rtlpriv, COMP_ERR, DBG_WARNING,
  505. "HW_VAR_ACM_CTRL acm set failed: eACI is %d\n",
  506. acm);
  507. break;
  508. }
  509. } else {
  510. switch (e_aci) {
  511. case AC0_BE:
  512. acm_ctrl &= (~ACMHW_BEQEN);
  513. break;
  514. case AC2_VI:
  515. acm_ctrl &= (~ACMHW_VIQEN);
  516. break;
  517. case AC3_VO:
  518. acm_ctrl &= (~ACMHW_BEQEN);
  519. break;
  520. default:
  521. RT_TRACE(rtlpriv, COMP_ERR, DBG_DMESG,
  522. "switch case not process\n");
  523. break;
  524. }
  525. }
  526. RT_TRACE(rtlpriv, COMP_QOS, DBG_TRACE,
  527. "SetHwReg8190pci(): [HW_VAR_ACM_CTRL] Write 0x%X\n",
  528. acm_ctrl);
  529. rtl_write_byte(rtlpriv, REG_ACMHWCTRL, acm_ctrl);
  530. }
  531. break;
  532. case HW_VAR_RCR:{
  533. rtl_write_dword(rtlpriv, REG_RCR, ((u32 *)(val))[0]);
  534. rtlpci->receive_config = ((u32 *)(val))[0];
  535. }
  536. break;
  537. case HW_VAR_RETRY_LIMIT:{
  538. u8 retry_limit = ((u8 *)(val))[0];
  539. rtl_write_word(rtlpriv, REG_RETRY_LIMIT,
  540. retry_limit << RETRY_LIMIT_SHORT_SHIFT |
  541. retry_limit << RETRY_LIMIT_LONG_SHIFT);
  542. }
  543. break;
  544. case HW_VAR_DUAL_TSF_RST:
  545. rtl_write_byte(rtlpriv, REG_DUAL_TSF_RST, (BIT(0) | BIT(1)));
  546. break;
  547. case HW_VAR_EFUSE_BYTES:
  548. efuse->efuse_usedbytes = *((u16 *)val);
  549. break;
  550. case HW_VAR_EFUSE_USAGE:
  551. efuse->efuse_usedpercentage = *((u8 *)val);
  552. break;
  553. case HW_VAR_IO_CMD:
  554. rtl92ee_phy_set_io_cmd(hw, (*(enum io_type *)val));
  555. break;
  556. case HW_VAR_SET_RPWM:{
  557. u8 rpwm_val;
  558. rpwm_val = rtl_read_byte(rtlpriv, REG_PCIE_HRPWM);
  559. udelay(1);
  560. if (rpwm_val & BIT(7)) {
  561. rtl_write_byte(rtlpriv, REG_PCIE_HRPWM, (*(u8 *)val));
  562. } else {
  563. rtl_write_byte(rtlpriv, REG_PCIE_HRPWM,
  564. ((*(u8 *)val) | BIT(7)));
  565. }
  566. }
  567. break;
  568. case HW_VAR_H2C_FW_PWRMODE:
  569. rtl92ee_set_fw_pwrmode_cmd(hw, (*(u8 *)val));
  570. break;
  571. case HW_VAR_FW_PSMODE_STATUS:
  572. ppsc->fw_current_inpsmode = *((bool *)val);
  573. break;
  574. case HW_VAR_RESUME_CLK_ON:
  575. _rtl92ee_set_fw_ps_rf_on(hw);
  576. break;
  577. case HW_VAR_FW_LPS_ACTION:{
  578. bool b_enter_fwlps = *((bool *)val);
  579. if (b_enter_fwlps)
  580. _rtl92ee_fwlps_enter(hw);
  581. else
  582. _rtl92ee_fwlps_leave(hw);
  583. }
  584. break;
  585. case HW_VAR_H2C_FW_JOINBSSRPT:{
  586. u8 mstatus = (*(u8 *)val);
  587. if (mstatus == RT_MEDIA_CONNECT) {
  588. rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_AID, NULL);
  589. _rtl92ee_download_rsvd_page(hw);
  590. }
  591. rtl92ee_set_fw_media_status_rpt_cmd(hw, mstatus);
  592. }
  593. break;
  594. case HW_VAR_H2C_FW_P2P_PS_OFFLOAD:
  595. rtl92ee_set_p2p_ps_offload_cmd(hw, (*(u8 *)val));
  596. break;
  597. case HW_VAR_AID:{
  598. u16 u2btmp;
  599. u2btmp = rtl_read_word(rtlpriv, REG_BCN_PSR_RPT);
  600. u2btmp &= 0xC000;
  601. rtl_write_word(rtlpriv, REG_BCN_PSR_RPT,
  602. (u2btmp | mac->assoc_id));
  603. }
  604. break;
  605. case HW_VAR_CORRECT_TSF:{
  606. u8 btype_ibss = ((u8 *)(val))[0];
  607. if (btype_ibss)
  608. _rtl92ee_stop_tx_beacon(hw);
  609. _rtl92ee_set_bcn_ctrl_reg(hw, 0, BIT(3));
  610. rtl_write_dword(rtlpriv, REG_TSFTR,
  611. (u32)(mac->tsf & 0xffffffff));
  612. rtl_write_dword(rtlpriv, REG_TSFTR + 4,
  613. (u32)((mac->tsf >> 32) & 0xffffffff));
  614. _rtl92ee_set_bcn_ctrl_reg(hw, BIT(3), 0);
  615. if (btype_ibss)
  616. _rtl92ee_resume_tx_beacon(hw);
  617. }
  618. break;
  619. case HW_VAR_KEEP_ALIVE: {
  620. u8 array[2];
  621. array[0] = 0xff;
  622. array[1] = *((u8 *)val);
  623. rtl92ee_fill_h2c_cmd(hw, H2C_92E_KEEP_ALIVE_CTRL, 2, array);
  624. }
  625. break;
  626. default:
  627. RT_TRACE(rtlpriv, COMP_ERR, DBG_DMESG,
  628. "switch case not process %x\n", variable);
  629. break;
  630. }
  631. }
  632. static bool _rtl92ee_llt_table_init(struct ieee80211_hw *hw)
  633. {
  634. struct rtl_priv *rtlpriv = rtl_priv(hw);
  635. u8 txpktbuf_bndy;
  636. u8 u8tmp, testcnt = 0;
  637. txpktbuf_bndy = 0xFA;
  638. rtl_write_dword(rtlpriv, REG_RQPN, 0x80E90808);
  639. rtl_write_byte(rtlpriv, REG_TRXFF_BNDY, txpktbuf_bndy);
  640. rtl_write_word(rtlpriv, REG_TRXFF_BNDY + 2, 0x3d00 - 1);
  641. rtl_write_byte(rtlpriv, REG_DWBCN0_CTRL + 1, txpktbuf_bndy);
  642. rtl_write_byte(rtlpriv, REG_DWBCN1_CTRL + 1, txpktbuf_bndy);
  643. rtl_write_byte(rtlpriv, REG_BCNQ_BDNY, txpktbuf_bndy);
  644. rtl_write_byte(rtlpriv, REG_BCNQ1_BDNY, txpktbuf_bndy);
  645. rtl_write_byte(rtlpriv, REG_MGQ_BDNY, txpktbuf_bndy);
  646. rtl_write_byte(rtlpriv, 0x45D, txpktbuf_bndy);
  647. rtl_write_byte(rtlpriv, REG_PBP, 0x31);
  648. rtl_write_byte(rtlpriv, REG_RX_DRVINFO_SZ, 0x4);
  649. u8tmp = rtl_read_byte(rtlpriv, REG_AUTO_LLT + 2);
  650. rtl_write_byte(rtlpriv, REG_AUTO_LLT + 2, u8tmp | BIT(0));
  651. while (u8tmp & BIT(0)) {
  652. u8tmp = rtl_read_byte(rtlpriv, REG_AUTO_LLT + 2);
  653. udelay(10);
  654. testcnt++;
  655. if (testcnt > 10)
  656. break;
  657. }
  658. return true;
  659. }
  660. static void _rtl92ee_gen_refresh_led_state(struct ieee80211_hw *hw)
  661. {
  662. struct rtl_priv *rtlpriv = rtl_priv(hw);
  663. struct rtl_pci_priv *pcipriv = rtl_pcipriv(hw);
  664. struct rtl_ps_ctl *ppsc = rtl_psc(rtl_priv(hw));
  665. struct rtl_led *pled0 = &pcipriv->ledctl.sw_led0;
  666. if (rtlpriv->rtlhal.up_first_time)
  667. return;
  668. if (ppsc->rfoff_reason == RF_CHANGE_BY_IPS)
  669. rtl92ee_sw_led_on(hw, pled0);
  670. else if (ppsc->rfoff_reason == RF_CHANGE_BY_INIT)
  671. rtl92ee_sw_led_on(hw, pled0);
  672. else
  673. rtl92ee_sw_led_off(hw, pled0);
  674. }
  675. static bool _rtl92ee_init_mac(struct ieee80211_hw *hw)
  676. {
  677. struct rtl_priv *rtlpriv = rtl_priv(hw);
  678. struct rtl_pci *rtlpci = rtl_pcidev(rtl_pcipriv(hw));
  679. struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw));
  680. u8 bytetmp;
  681. u16 wordtmp;
  682. u32 dwordtmp;
  683. rtl_write_byte(rtlpriv, REG_RSV_CTRL, 0x0);
  684. dwordtmp = rtl_read_dword(rtlpriv, REG_SYS_CFG1);
  685. if (dwordtmp & BIT(24)) {
  686. rtl_write_byte(rtlpriv, 0x7c, 0xc3);
  687. } else {
  688. bytetmp = rtl_read_byte(rtlpriv, 0x16);
  689. rtl_write_byte(rtlpriv, 0x16, bytetmp | BIT(4) | BIT(6));
  690. rtl_write_byte(rtlpriv, 0x7c, 0x83);
  691. }
  692. /* 1. 40Mhz crystal source*/
  693. bytetmp = rtl_read_byte(rtlpriv, REG_AFE_CTRL2);
  694. bytetmp &= 0xfb;
  695. rtl_write_byte(rtlpriv, REG_AFE_CTRL2, bytetmp);
  696. dwordtmp = rtl_read_dword(rtlpriv, REG_AFE_CTRL4);
  697. dwordtmp &= 0xfffffc7f;
  698. rtl_write_dword(rtlpriv, REG_AFE_CTRL4, dwordtmp);
  699. /* 2. 92E AFE parameter
  700. * MP chip then check version
  701. */
  702. bytetmp = rtl_read_byte(rtlpriv, REG_AFE_CTRL2);
  703. bytetmp &= 0xbf;
  704. rtl_write_byte(rtlpriv, REG_AFE_CTRL2, bytetmp);
  705. dwordtmp = rtl_read_dword(rtlpriv, REG_AFE_CTRL4);
  706. dwordtmp &= 0xffdfffff;
  707. rtl_write_dword(rtlpriv, REG_AFE_CTRL4, dwordtmp);
  708. /* HW Power on sequence */
  709. if (!rtl_hal_pwrseqcmdparsing(rtlpriv, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK,
  710. PWR_INTF_PCI_MSK,
  711. RTL8192E_NIC_ENABLE_FLOW)) {
  712. RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD,
  713. "init MAC Fail as rtl_hal_pwrseqcmdparsing\n");
  714. return false;
  715. }
  716. /* Release MAC IO register reset */
  717. bytetmp = rtl_read_byte(rtlpriv, REG_CR);
  718. bytetmp = 0xff;
  719. rtl_write_byte(rtlpriv, REG_CR, bytetmp);
  720. mdelay(2);
  721. bytetmp = 0x7f;
  722. rtl_write_byte(rtlpriv, REG_HWSEQ_CTRL, bytetmp);
  723. mdelay(2);
  724. /* Add for wakeup online */
  725. bytetmp = rtl_read_byte(rtlpriv, REG_SYS_CLKR);
  726. rtl_write_byte(rtlpriv, REG_SYS_CLKR, bytetmp | BIT(3));
  727. bytetmp = rtl_read_byte(rtlpriv, REG_GPIO_MUXCFG + 1);
  728. rtl_write_byte(rtlpriv, REG_GPIO_MUXCFG + 1, bytetmp & (~BIT(4)));
  729. /* Release MAC IO register reset */
  730. rtl_write_word(rtlpriv, REG_CR, 0x2ff);
  731. if (!rtlhal->mac_func_enable) {
  732. if (_rtl92ee_llt_table_init(hw) == false) {
  733. RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD,
  734. "LLT table init fail\n");
  735. return false;
  736. }
  737. }
  738. rtl_write_dword(rtlpriv, REG_HISR, 0xffffffff);
  739. rtl_write_dword(rtlpriv, REG_HISRE, 0xffffffff);
  740. wordtmp = rtl_read_word(rtlpriv, REG_TRXDMA_CTRL);
  741. wordtmp &= 0xf;
  742. wordtmp |= 0xF5B1;
  743. rtl_write_word(rtlpriv, REG_TRXDMA_CTRL, wordtmp);
  744. /* Reported Tx status from HW for rate adaptive.*/
  745. rtl_write_byte(rtlpriv, REG_FWHW_TXQ_CTRL + 1, 0x1F);
  746. /* Set RCR register */
  747. rtl_write_dword(rtlpriv, REG_RCR, rtlpci->receive_config);
  748. rtl_write_word(rtlpriv, REG_RXFLTMAP2, 0xffff);
  749. /* Set TCR register */
  750. rtl_write_dword(rtlpriv, REG_TCR, rtlpci->transmit_config);
  751. /* Set TX/RX descriptor physical address(from OS API). */
  752. rtl_write_dword(rtlpriv, REG_BCNQ_DESA,
  753. ((u64)rtlpci->tx_ring[BEACON_QUEUE].buffer_desc_dma) &
  754. DMA_BIT_MASK(32));
  755. rtl_write_dword(rtlpriv, REG_MGQ_DESA,
  756. (u64)rtlpci->tx_ring[MGNT_QUEUE].buffer_desc_dma &
  757. DMA_BIT_MASK(32));
  758. rtl_write_dword(rtlpriv, REG_VOQ_DESA,
  759. (u64)rtlpci->tx_ring[VO_QUEUE].buffer_desc_dma &
  760. DMA_BIT_MASK(32));
  761. rtl_write_dword(rtlpriv, REG_VIQ_DESA,
  762. (u64)rtlpci->tx_ring[VI_QUEUE].buffer_desc_dma &
  763. DMA_BIT_MASK(32));
  764. rtl_write_dword(rtlpriv, REG_BEQ_DESA,
  765. (u64)rtlpci->tx_ring[BE_QUEUE].buffer_desc_dma &
  766. DMA_BIT_MASK(32));
  767. dwordtmp = rtl_read_dword(rtlpriv, REG_BEQ_DESA);
  768. rtl_write_dword(rtlpriv, REG_BKQ_DESA,
  769. (u64)rtlpci->tx_ring[BK_QUEUE].buffer_desc_dma &
  770. DMA_BIT_MASK(32));
  771. rtl_write_dword(rtlpriv, REG_HQ0_DESA,
  772. (u64)rtlpci->tx_ring[HIGH_QUEUE].buffer_desc_dma &
  773. DMA_BIT_MASK(32));
  774. rtl_write_dword(rtlpriv, REG_RX_DESA,
  775. (u64)rtlpci->rx_ring[RX_MPDU_QUEUE].dma &
  776. DMA_BIT_MASK(32));
  777. /* if we want to support 64 bit DMA, we should set it here,
  778. * but now we do not support 64 bit DMA
  779. */
  780. rtl_write_dword(rtlpriv, REG_TSFTIMER_HCI, 0x3fffffff);
  781. bytetmp = rtl_read_byte(rtlpriv, REG_PCIE_CTRL_REG + 3);
  782. rtl_write_byte(rtlpriv, REG_PCIE_CTRL_REG + 3, bytetmp | 0xF7);
  783. rtl_write_dword(rtlpriv, REG_INT_MIG, 0);
  784. rtl_write_dword(rtlpriv, REG_MCUTST_1, 0x0);
  785. rtl_write_word(rtlpriv, REG_MGQ_TXBD_NUM,
  786. TX_DESC_NUM_92E | ((RTL8192EE_SEG_NUM << 12) & 0x3000));
  787. rtl_write_word(rtlpriv, REG_VOQ_TXBD_NUM,
  788. TX_DESC_NUM_92E | ((RTL8192EE_SEG_NUM << 12) & 0x3000));
  789. rtl_write_word(rtlpriv, REG_VIQ_TXBD_NUM,
  790. TX_DESC_NUM_92E | ((RTL8192EE_SEG_NUM << 12) & 0x3000));
  791. rtl_write_word(rtlpriv, REG_BEQ_TXBD_NUM,
  792. TX_DESC_NUM_92E | ((RTL8192EE_SEG_NUM << 12) & 0x3000));
  793. rtl_write_word(rtlpriv, REG_VOQ_TXBD_NUM,
  794. TX_DESC_NUM_92E | ((RTL8192EE_SEG_NUM << 12) & 0x3000));
  795. rtl_write_word(rtlpriv, REG_BKQ_TXBD_NUM,
  796. TX_DESC_NUM_92E | ((RTL8192EE_SEG_NUM << 12) & 0x3000));
  797. rtl_write_word(rtlpriv, REG_HI0Q_TXBD_NUM,
  798. TX_DESC_NUM_92E | ((RTL8192EE_SEG_NUM << 12) & 0x3000));
  799. rtl_write_word(rtlpriv, REG_HI1Q_TXBD_NUM,
  800. TX_DESC_NUM_92E | ((RTL8192EE_SEG_NUM << 12) & 0x3000));
  801. rtl_write_word(rtlpriv, REG_HI2Q_TXBD_NUM,
  802. TX_DESC_NUM_92E | ((RTL8192EE_SEG_NUM << 12) & 0x3000));
  803. rtl_write_word(rtlpriv, REG_HI3Q_TXBD_NUM,
  804. TX_DESC_NUM_92E | ((RTL8192EE_SEG_NUM << 12) & 0x3000));
  805. rtl_write_word(rtlpriv, REG_HI4Q_TXBD_NUM,
  806. TX_DESC_NUM_92E | ((RTL8192EE_SEG_NUM << 12) & 0x3000));
  807. rtl_write_word(rtlpriv, REG_HI5Q_TXBD_NUM,
  808. TX_DESC_NUM_92E | ((RTL8192EE_SEG_NUM << 12) & 0x3000));
  809. rtl_write_word(rtlpriv, REG_HI6Q_TXBD_NUM,
  810. TX_DESC_NUM_92E | ((RTL8192EE_SEG_NUM << 12) & 0x3000));
  811. rtl_write_word(rtlpriv, REG_HI7Q_TXBD_NUM,
  812. TX_DESC_NUM_92E | ((RTL8192EE_SEG_NUM << 12) & 0x3000));
  813. /*Rx*/
  814. #if (DMA_IS_64BIT == 1)
  815. rtl_write_word(rtlpriv, REG_RX_RXBD_NUM,
  816. RX_DESC_NUM_92E |
  817. ((RTL8192EE_SEG_NUM << 13) & 0x6000) | 0x8000);
  818. #else
  819. rtl_write_word(rtlpriv, REG_RX_RXBD_NUM,
  820. RX_DESC_NUM_92E |
  821. ((RTL8192EE_SEG_NUM << 13) & 0x6000) | 0x0000);
  822. #endif
  823. rtl_write_dword(rtlpriv, REG_TSFTIMER_HCI, 0XFFFFFFFF);
  824. _rtl92ee_gen_refresh_led_state(hw);
  825. return true;
  826. }
  827. static void _rtl92ee_hw_configure(struct ieee80211_hw *hw)
  828. {
  829. struct rtl_priv *rtlpriv = rtl_priv(hw);
  830. struct rtl_pci *rtlpci = rtl_pcidev(rtl_pcipriv(hw));
  831. u32 reg_rrsr;
  832. reg_rrsr = RATE_ALL_CCK | RATE_ALL_OFDM_AG;
  833. /* Init value for RRSR. */
  834. rtl_write_dword(rtlpriv, REG_RRSR, reg_rrsr);
  835. /* ARFB table 9 for 11ac 5G 2SS */
  836. rtl_write_dword(rtlpriv, REG_ARFR0, 0x00000010);
  837. rtl_write_dword(rtlpriv, REG_ARFR0 + 4, 0x3e0ff000);
  838. /* ARFB table 10 for 11ac 5G 1SS */
  839. rtl_write_dword(rtlpriv, REG_ARFR1, 0x00000010);
  840. rtl_write_dword(rtlpriv, REG_ARFR1 + 4, 0x000ff000);
  841. /* Set SLOT time */
  842. rtl_write_byte(rtlpriv, REG_SLOT, 0x09);
  843. /* CF-End setting. */
  844. rtl_write_word(rtlpriv, REG_FWHW_TXQ_CTRL, 0x1F80);
  845. /* Set retry limit */
  846. rtl_write_word(rtlpriv, REG_RETRY_LIMIT, 0x0707);
  847. /* BAR settings */
  848. rtl_write_dword(rtlpriv, REG_BAR_MODE_CTRL, 0x0201ffff);
  849. /* Set Data / Response auto rate fallack retry count */
  850. rtl_write_dword(rtlpriv, REG_DARFRC, 0x01000000);
  851. rtl_write_dword(rtlpriv, REG_DARFRC + 4, 0x07060504);
  852. rtl_write_dword(rtlpriv, REG_RARFRC, 0x01000000);
  853. rtl_write_dword(rtlpriv, REG_RARFRC + 4, 0x07060504);
  854. /* Beacon related, for rate adaptive */
  855. rtl_write_byte(rtlpriv, REG_ATIMWND, 0x2);
  856. rtl_write_byte(rtlpriv, REG_BCN_MAX_ERR, 0xff);
  857. rtlpci->reg_bcn_ctrl_val = 0x1d;
  858. rtl_write_byte(rtlpriv, REG_BCN_CTRL, rtlpci->reg_bcn_ctrl_val);
  859. /* Marked out by Bruce, 2010-09-09.
  860. * This register is configured for the 2nd Beacon (multiple BSSID).
  861. * We shall disable this register if we only support 1 BSSID.
  862. * vivi guess 92d also need this, also 92d now doesnot set this reg
  863. */
  864. rtl_write_byte(rtlpriv, REG_BCN_CTRL_1, 0);
  865. /* TBTT prohibit hold time. Suggested by designer TimChen. */
  866. rtl_write_byte(rtlpriv, REG_TBTT_PROHIBIT + 1, 0xff); /* 8 ms */
  867. rtl_write_byte(rtlpriv, REG_PIFS, 0);
  868. rtl_write_byte(rtlpriv, REG_AGGR_BREAK_TIME, 0x16);
  869. rtl_write_word(rtlpriv, REG_NAV_PROT_LEN, 0x0040);
  870. rtl_write_word(rtlpriv, REG_PROT_MODE_CTRL, 0x08ff);
  871. /* For Rx TP. Suggested by SD1 Richard. Added by tynli. 2010.04.12.*/
  872. rtl_write_dword(rtlpriv, REG_FAST_EDCA_CTRL, 0x03086666);
  873. /* ACKTO for IOT issue. */
  874. rtl_write_byte(rtlpriv, REG_ACKTO, 0x40);
  875. /* Set Spec SIFS (used in NAV) */
  876. rtl_write_word(rtlpriv, REG_SPEC_SIFS, 0x100a);
  877. rtl_write_word(rtlpriv, REG_MAC_SPEC_SIFS, 0x100a);
  878. /* Set SIFS for CCK */
  879. rtl_write_word(rtlpriv, REG_SIFS_CTX, 0x100a);
  880. /* Set SIFS for OFDM */
  881. rtl_write_word(rtlpriv, REG_SIFS_TRX, 0x100a);
  882. /* Note Data sheet don't define */
  883. rtl_write_word(rtlpriv, 0x4C7, 0x80);
  884. rtl_write_byte(rtlpriv, REG_RX_PKT_LIMIT, 0x20);
  885. rtl_write_word(rtlpriv, REG_MAX_AGGR_NUM, 0x1717);
  886. /* Set Multicast Address. 2009.01.07. by tynli. */
  887. rtl_write_dword(rtlpriv, REG_MAR, 0xffffffff);
  888. rtl_write_dword(rtlpriv, REG_MAR + 4, 0xffffffff);
  889. }
  890. static void _rtl92ee_enable_aspm_back_door(struct ieee80211_hw *hw)
  891. {
  892. struct rtl_priv *rtlpriv = rtl_priv(hw);
  893. struct rtl_ps_ctl *ppsc = rtl_psc(rtl_priv(hw));
  894. u32 tmp32 = 0, count = 0;
  895. u8 tmp8 = 0;
  896. rtl_write_word(rtlpriv, REG_BACKDOOR_DBI_DATA, 0x78);
  897. rtl_write_byte(rtlpriv, REG_BACKDOOR_DBI_DATA + 2, 0x2);
  898. tmp8 = rtl_read_byte(rtlpriv, REG_BACKDOOR_DBI_DATA + 2);
  899. count = 0;
  900. while (tmp8 && count < 20) {
  901. udelay(10);
  902. tmp8 = rtl_read_byte(rtlpriv, REG_BACKDOOR_DBI_DATA + 2);
  903. count++;
  904. }
  905. if (0 == tmp8) {
  906. tmp32 = rtl_read_dword(rtlpriv, REG_BACKDOOR_DBI_RDATA);
  907. if ((tmp32 & 0xff00) != 0x2000) {
  908. tmp32 &= 0xffff00ff;
  909. rtl_write_dword(rtlpriv, REG_BACKDOOR_DBI_WDATA,
  910. tmp32 | BIT(13));
  911. rtl_write_word(rtlpriv, REG_BACKDOOR_DBI_DATA, 0xf078);
  912. rtl_write_byte(rtlpriv, REG_BACKDOOR_DBI_DATA + 2, 0x1);
  913. tmp8 = rtl_read_byte(rtlpriv,
  914. REG_BACKDOOR_DBI_DATA + 2);
  915. count = 0;
  916. while (tmp8 && count < 20) {
  917. udelay(10);
  918. tmp8 = rtl_read_byte(rtlpriv,
  919. REG_BACKDOOR_DBI_DATA + 2);
  920. count++;
  921. }
  922. }
  923. }
  924. rtl_write_word(rtlpriv, REG_BACKDOOR_DBI_DATA, 0x70c);
  925. rtl_write_byte(rtlpriv, REG_BACKDOOR_DBI_DATA + 2, 0x2);
  926. tmp8 = rtl_read_byte(rtlpriv, REG_BACKDOOR_DBI_DATA + 2);
  927. count = 0;
  928. while (tmp8 && count < 20) {
  929. udelay(10);
  930. tmp8 = rtl_read_byte(rtlpriv, REG_BACKDOOR_DBI_DATA + 2);
  931. count++;
  932. }
  933. if (0 == tmp8) {
  934. tmp32 = rtl_read_dword(rtlpriv, REG_BACKDOOR_DBI_RDATA);
  935. rtl_write_dword(rtlpriv, REG_BACKDOOR_DBI_WDATA,
  936. tmp32 | BIT(31));
  937. rtl_write_word(rtlpriv, REG_BACKDOOR_DBI_DATA, 0xf70c);
  938. rtl_write_byte(rtlpriv, REG_BACKDOOR_DBI_DATA + 2, 0x1);
  939. }
  940. tmp8 = rtl_read_byte(rtlpriv, REG_BACKDOOR_DBI_DATA + 2);
  941. count = 0;
  942. while (tmp8 && count < 20) {
  943. udelay(10);
  944. tmp8 = rtl_read_byte(rtlpriv, REG_BACKDOOR_DBI_DATA + 2);
  945. count++;
  946. }
  947. rtl_write_word(rtlpriv, REG_BACKDOOR_DBI_DATA, 0x718);
  948. rtl_write_byte(rtlpriv, REG_BACKDOOR_DBI_DATA + 2, 0x2);
  949. tmp8 = rtl_read_byte(rtlpriv, REG_BACKDOOR_DBI_DATA + 2);
  950. count = 0;
  951. while (tmp8 && count < 20) {
  952. udelay(10);
  953. tmp8 = rtl_read_byte(rtlpriv, REG_BACKDOOR_DBI_DATA + 2);
  954. count++;
  955. }
  956. if (ppsc->support_backdoor || (0 == tmp8)) {
  957. tmp32 = rtl_read_dword(rtlpriv, REG_BACKDOOR_DBI_RDATA);
  958. rtl_write_dword(rtlpriv, REG_BACKDOOR_DBI_WDATA,
  959. tmp32 | BIT(11) | BIT(12));
  960. rtl_write_word(rtlpriv, REG_BACKDOOR_DBI_DATA, 0xf718);
  961. rtl_write_byte(rtlpriv, REG_BACKDOOR_DBI_DATA + 2, 0x1);
  962. }
  963. tmp8 = rtl_read_byte(rtlpriv, REG_BACKDOOR_DBI_DATA + 2);
  964. count = 0;
  965. while (tmp8 && count < 20) {
  966. udelay(10);
  967. tmp8 = rtl_read_byte(rtlpriv, REG_BACKDOOR_DBI_DATA + 2);
  968. count++;
  969. }
  970. }
  971. void rtl92ee_enable_hw_security_config(struct ieee80211_hw *hw)
  972. {
  973. struct rtl_priv *rtlpriv = rtl_priv(hw);
  974. u8 sec_reg_value;
  975. u8 tmp;
  976. RT_TRACE(rtlpriv, COMP_INIT, DBG_DMESG,
  977. "PairwiseEncAlgorithm = %d GroupEncAlgorithm = %d\n",
  978. rtlpriv->sec.pairwise_enc_algorithm,
  979. rtlpriv->sec.group_enc_algorithm);
  980. if (rtlpriv->cfg->mod_params->sw_crypto || rtlpriv->sec.use_sw_sec) {
  981. RT_TRACE(rtlpriv, COMP_SEC, DBG_DMESG,
  982. "not open hw encryption\n");
  983. return;
  984. }
  985. sec_reg_value = SCR_TXENCENABLE | SCR_RXDECENABLE;
  986. if (rtlpriv->sec.use_defaultkey) {
  987. sec_reg_value |= SCR_TXUSEDK;
  988. sec_reg_value |= SCR_RXUSEDK;
  989. }
  990. sec_reg_value |= (SCR_RXBCUSEDK | SCR_TXBCUSEDK);
  991. tmp = rtl_read_byte(rtlpriv, REG_CR + 1);
  992. rtl_write_byte(rtlpriv, REG_CR + 1, tmp | BIT(1));
  993. RT_TRACE(rtlpriv, COMP_SEC, DBG_DMESG,
  994. "The SECR-value %x\n", sec_reg_value);
  995. rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_WPA_CONFIG, &sec_reg_value);
  996. }
  997. int rtl92ee_hw_init(struct ieee80211_hw *hw)
  998. {
  999. struct rtl_priv *rtlpriv = rtl_priv(hw);
  1000. struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw));
  1001. struct rtl_mac *mac = rtl_mac(rtl_priv(hw));
  1002. struct rtl_phy *rtlphy = &rtlpriv->phy;
  1003. struct rtl_ps_ctl *ppsc = rtl_psc(rtl_priv(hw));
  1004. bool rtstatus = true;
  1005. int err = 0;
  1006. u8 tmp_u1b, u1byte;
  1007. u32 tmp_u4b;
  1008. RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD, " Rtl8192EE hw init\n");
  1009. rtlpriv->rtlhal.being_init_adapter = true;
  1010. rtlpriv->intf_ops->disable_aspm(hw);
  1011. tmp_u1b = rtl_read_byte(rtlpriv, REG_SYS_CLKR+1);
  1012. u1byte = rtl_read_byte(rtlpriv, REG_CR);
  1013. if ((tmp_u1b & BIT(3)) && (u1byte != 0 && u1byte != 0xEA)) {
  1014. rtlhal->mac_func_enable = true;
  1015. } else {
  1016. rtlhal->mac_func_enable = false;
  1017. rtlhal->fw_ps_state = FW_PS_STATE_ALL_ON_92E;
  1018. }
  1019. rtstatus = _rtl92ee_init_mac(hw);
  1020. rtl_write_byte(rtlpriv, 0x577, 0x03);
  1021. /*for Crystal 40 Mhz setting */
  1022. rtl_write_byte(rtlpriv, REG_AFE_CTRL4, 0x2A);
  1023. rtl_write_byte(rtlpriv, REG_AFE_CTRL4 + 1, 0x00);
  1024. rtl_write_byte(rtlpriv, REG_AFE_CTRL2, 0x83);
  1025. /*Forced the antenna b to wifi */
  1026. if (rtlpriv->btcoexist.btc_info.btcoexist == 1) {
  1027. rtl_write_byte(rtlpriv, 0x64, 0);
  1028. rtl_write_byte(rtlpriv, 0x65, 1);
  1029. }
  1030. if (!rtstatus) {
  1031. RT_TRACE(rtlpriv, COMP_ERR, DBG_EMERG, "Init MAC failed\n");
  1032. err = 1;
  1033. return err;
  1034. }
  1035. rtlhal->rx_tag = 0;
  1036. rtl_write_word(rtlpriv, REG_PCIE_CTRL_REG, 0x8000);
  1037. err = rtl92ee_download_fw(hw, false);
  1038. if (err) {
  1039. RT_TRACE(rtlpriv, COMP_ERR, DBG_WARNING,
  1040. "Failed to download FW. Init HW without FW now..\n");
  1041. err = 1;
  1042. rtlhal->fw_ready = false;
  1043. return err;
  1044. }
  1045. rtlhal->fw_ready = true;
  1046. /*fw related variable initialize */
  1047. ppsc->fw_current_inpsmode = false;
  1048. rtlhal->fw_ps_state = FW_PS_STATE_ALL_ON_92E;
  1049. rtlhal->fw_clk_change_in_progress = false;
  1050. rtlhal->allow_sw_to_change_hwclc = false;
  1051. rtlhal->last_hmeboxnum = 0;
  1052. rtl92ee_phy_mac_config(hw);
  1053. rtl92ee_phy_bb_config(hw);
  1054. rtl92ee_phy_rf_config(hw);
  1055. rtlphy->rfreg_chnlval[0] = rtl_get_rfreg(hw, RF90_PATH_A,
  1056. RF_CHNLBW, RFREG_OFFSET_MASK);
  1057. rtlphy->rfreg_chnlval[1] = rtl_get_rfreg(hw, RF90_PATH_B,
  1058. RF_CHNLBW, RFREG_OFFSET_MASK);
  1059. rtlphy->backup_rf_0x1a = (u32)rtl_get_rfreg(hw, RF90_PATH_A, RF_RX_G1,
  1060. RFREG_OFFSET_MASK);
  1061. rtlphy->rfreg_chnlval[0] = (rtlphy->rfreg_chnlval[0] & 0xfffff3ff) |
  1062. BIT(10) | BIT(11);
  1063. rtl_set_rfreg(hw, RF90_PATH_A, RF_CHNLBW, RFREG_OFFSET_MASK,
  1064. rtlphy->rfreg_chnlval[0]);
  1065. rtl_set_rfreg(hw, RF90_PATH_B, RF_CHNLBW, RFREG_OFFSET_MASK,
  1066. rtlphy->rfreg_chnlval[0]);
  1067. /*---- Set CCK and OFDM Block "ON"----*/
  1068. rtl_set_bbreg(hw, RFPGA0_RFMOD, BCCKEN, 0x1);
  1069. rtl_set_bbreg(hw, RFPGA0_RFMOD, BOFDMEN, 0x1);
  1070. /* Must set this,
  1071. * otherwise the rx sensitivity will be very pool. Maddest
  1072. */
  1073. rtl_set_rfreg(hw, RF90_PATH_A, 0xB1, RFREG_OFFSET_MASK, 0x54418);
  1074. /*Set Hardware(MAC default setting.)*/
  1075. _rtl92ee_hw_configure(hw);
  1076. rtlhal->mac_func_enable = true;
  1077. rtl_cam_reset_all_entry(hw);
  1078. rtl92ee_enable_hw_security_config(hw);
  1079. ppsc->rfpwr_state = ERFON;
  1080. rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_ETHER_ADDR, mac->mac_addr);
  1081. _rtl92ee_enable_aspm_back_door(hw);
  1082. rtlpriv->intf_ops->enable_aspm(hw);
  1083. rtl92ee_bt_hw_init(hw);
  1084. rtlpriv->rtlhal.being_init_adapter = false;
  1085. if (ppsc->rfpwr_state == ERFON) {
  1086. if (rtlphy->iqk_initialized) {
  1087. rtl92ee_phy_iq_calibrate(hw, true);
  1088. } else {
  1089. rtl92ee_phy_iq_calibrate(hw, false);
  1090. rtlphy->iqk_initialized = true;
  1091. }
  1092. }
  1093. rtlphy->rfpath_rx_enable[0] = true;
  1094. if (rtlphy->rf_type == RF_2T2R)
  1095. rtlphy->rfpath_rx_enable[1] = true;
  1096. efuse_one_byte_read(hw, 0x1FA, &tmp_u1b);
  1097. if (!(tmp_u1b & BIT(0))) {
  1098. rtl_set_rfreg(hw, RF90_PATH_A, 0x15, 0x0F, 0x05);
  1099. RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD, "PA BIAS path A\n");
  1100. }
  1101. if ((!(tmp_u1b & BIT(1))) && (rtlphy->rf_type == RF_2T2R)) {
  1102. rtl_set_rfreg(hw, RF90_PATH_B, 0x15, 0x0F, 0x05);
  1103. RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD, "PA BIAS path B\n");
  1104. }
  1105. rtl_write_byte(rtlpriv, REG_NAV_UPPER, ((30000 + 127) / 128));
  1106. /*Fixed LDPC rx hang issue. */
  1107. tmp_u4b = rtl_read_dword(rtlpriv, REG_SYS_SWR_CTRL1);
  1108. rtl_write_byte(rtlpriv, REG_SYS_SWR_CTRL2, 0x75);
  1109. tmp_u4b = (tmp_u4b & 0xfff00fff) | (0x7E << 12);
  1110. rtl_write_dword(rtlpriv, REG_SYS_SWR_CTRL1, tmp_u4b);
  1111. rtl92ee_dm_init(hw);
  1112. rtl_write_dword(rtlpriv, 0x4fc, 0);
  1113. RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD,
  1114. "end of Rtl8192EE hw init %x\n", err);
  1115. return 0;
  1116. }
  1117. static enum version_8192e _rtl92ee_read_chip_version(struct ieee80211_hw *hw)
  1118. {
  1119. struct rtl_priv *rtlpriv = rtl_priv(hw);
  1120. struct rtl_phy *rtlphy = &rtlpriv->phy;
  1121. enum version_8192e version = VERSION_UNKNOWN;
  1122. u32 value32;
  1123. rtlphy->rf_type = RF_2T2R;
  1124. value32 = rtl_read_dword(rtlpriv, REG_SYS_CFG1);
  1125. if (value32 & TRP_VAUX_EN)
  1126. version = (enum version_8192e)VERSION_TEST_CHIP_2T2R_8192E;
  1127. else
  1128. version = (enum version_8192e)VERSION_NORMAL_CHIP_2T2R_8192E;
  1129. RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD,
  1130. "Chip RF Type: %s\n", (rtlphy->rf_type == RF_2T2R) ?
  1131. "RF_2T2R" : "RF_1T1R");
  1132. return version;
  1133. }
  1134. static int _rtl92ee_set_media_status(struct ieee80211_hw *hw,
  1135. enum nl80211_iftype type)
  1136. {
  1137. struct rtl_priv *rtlpriv = rtl_priv(hw);
  1138. u8 bt_msr = rtl_read_byte(rtlpriv, MSR) & 0xfc;
  1139. enum led_ctl_mode ledaction = LED_CTL_NO_LINK;
  1140. u8 mode = MSR_NOLINK;
  1141. switch (type) {
  1142. case NL80211_IFTYPE_UNSPECIFIED:
  1143. mode = MSR_NOLINK;
  1144. RT_TRACE(rtlpriv, COMP_INIT, DBG_TRACE,
  1145. "Set Network type to NO LINK!\n");
  1146. break;
  1147. case NL80211_IFTYPE_ADHOC:
  1148. case NL80211_IFTYPE_MESH_POINT:
  1149. mode = MSR_ADHOC;
  1150. RT_TRACE(rtlpriv, COMP_INIT, DBG_TRACE,
  1151. "Set Network type to Ad Hoc!\n");
  1152. break;
  1153. case NL80211_IFTYPE_STATION:
  1154. mode = MSR_INFRA;
  1155. ledaction = LED_CTL_LINK;
  1156. RT_TRACE(rtlpriv, COMP_INIT, DBG_TRACE,
  1157. "Set Network type to STA!\n");
  1158. break;
  1159. case NL80211_IFTYPE_AP:
  1160. mode = MSR_AP;
  1161. ledaction = LED_CTL_LINK;
  1162. RT_TRACE(rtlpriv, COMP_INIT, DBG_TRACE,
  1163. "Set Network type to AP!\n");
  1164. break;
  1165. default:
  1166. RT_TRACE(rtlpriv, COMP_ERR, DBG_EMERG,
  1167. "Network type %d not support!\n", type);
  1168. return 1;
  1169. }
  1170. /* MSR_INFRA == Link in infrastructure network;
  1171. * MSR_ADHOC == Link in ad hoc network;
  1172. * Therefore, check link state is necessary.
  1173. *
  1174. * MSR_AP == AP mode; link state is not cared here.
  1175. */
  1176. if (mode != MSR_AP && rtlpriv->mac80211.link_state < MAC80211_LINKED) {
  1177. mode = MSR_NOLINK;
  1178. ledaction = LED_CTL_NO_LINK;
  1179. }
  1180. if (mode == MSR_NOLINK || mode == MSR_INFRA) {
  1181. _rtl92ee_stop_tx_beacon(hw);
  1182. _rtl92ee_enable_bcn_sub_func(hw);
  1183. } else if (mode == MSR_ADHOC || mode == MSR_AP) {
  1184. _rtl92ee_resume_tx_beacon(hw);
  1185. _rtl92ee_disable_bcn_sub_func(hw);
  1186. } else {
  1187. RT_TRACE(rtlpriv, COMP_ERR, DBG_WARNING,
  1188. "Set HW_VAR_MEDIA_STATUS: No such media status(%x).\n",
  1189. mode);
  1190. }
  1191. rtl_write_byte(rtlpriv, (MSR), bt_msr | mode);
  1192. rtlpriv->cfg->ops->led_control(hw, ledaction);
  1193. if (mode == MSR_AP)
  1194. rtl_write_byte(rtlpriv, REG_BCNTCFG + 1, 0x00);
  1195. else
  1196. rtl_write_byte(rtlpriv, REG_BCNTCFG + 1, 0x66);
  1197. return 0;
  1198. }
  1199. void rtl92ee_set_check_bssid(struct ieee80211_hw *hw, bool check_bssid)
  1200. {
  1201. struct rtl_priv *rtlpriv = rtl_priv(hw);
  1202. struct rtl_pci *rtlpci = rtl_pcidev(rtl_pcipriv(hw));
  1203. u32 reg_rcr = rtlpci->receive_config;
  1204. if (rtlpriv->psc.rfpwr_state != ERFON)
  1205. return;
  1206. if (check_bssid) {
  1207. reg_rcr |= (RCR_CBSSID_DATA | RCR_CBSSID_BCN);
  1208. rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_RCR,
  1209. (u8 *)(&reg_rcr));
  1210. _rtl92ee_set_bcn_ctrl_reg(hw, 0, BIT(4));
  1211. } else {
  1212. reg_rcr &= (~(RCR_CBSSID_DATA | RCR_CBSSID_BCN));
  1213. _rtl92ee_set_bcn_ctrl_reg(hw, BIT(4), 0);
  1214. rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_RCR,
  1215. (u8 *)(&reg_rcr));
  1216. }
  1217. }
  1218. int rtl92ee_set_network_type(struct ieee80211_hw *hw, enum nl80211_iftype type)
  1219. {
  1220. struct rtl_priv *rtlpriv = rtl_priv(hw);
  1221. if (_rtl92ee_set_media_status(hw, type))
  1222. return -EOPNOTSUPP;
  1223. if (rtlpriv->mac80211.link_state == MAC80211_LINKED) {
  1224. if (type != NL80211_IFTYPE_AP &&
  1225. type != NL80211_IFTYPE_MESH_POINT)
  1226. rtl92ee_set_check_bssid(hw, true);
  1227. } else {
  1228. rtl92ee_set_check_bssid(hw, false);
  1229. }
  1230. return 0;
  1231. }
  1232. /* don't set REG_EDCA_BE_PARAM here because mac80211 will send pkt when scan */
  1233. void rtl92ee_set_qos(struct ieee80211_hw *hw, int aci)
  1234. {
  1235. struct rtl_priv *rtlpriv = rtl_priv(hw);
  1236. rtl92ee_dm_init_edca_turbo(hw);
  1237. switch (aci) {
  1238. case AC1_BK:
  1239. rtl_write_dword(rtlpriv, REG_EDCA_BK_PARAM, 0xa44f);
  1240. break;
  1241. case AC0_BE:
  1242. /* rtl_write_dword(rtlpriv, REG_EDCA_BE_PARAM, u4b_ac_param); */
  1243. break;
  1244. case AC2_VI:
  1245. rtl_write_dword(rtlpriv, REG_EDCA_VI_PARAM, 0x5e4322);
  1246. break;
  1247. case AC3_VO:
  1248. rtl_write_dword(rtlpriv, REG_EDCA_VO_PARAM, 0x2f3222);
  1249. break;
  1250. default:
  1251. RT_ASSERT(false, "invalid aci: %d !\n", aci);
  1252. break;
  1253. }
  1254. }
  1255. static void rtl92ee_clear_interrupt(struct ieee80211_hw *hw)
  1256. {
  1257. struct rtl_priv *rtlpriv = rtl_priv(hw);
  1258. u32 tmp;
  1259. tmp = rtl_read_dword(rtlpriv, REG_HISR);
  1260. rtl_write_dword(rtlpriv, REG_HISR, tmp);
  1261. tmp = rtl_read_dword(rtlpriv, REG_HISRE);
  1262. rtl_write_dword(rtlpriv, REG_HISRE, tmp);
  1263. tmp = rtl_read_dword(rtlpriv, REG_HSISR);
  1264. rtl_write_dword(rtlpriv, REG_HSISR, tmp);
  1265. }
  1266. void rtl92ee_enable_interrupt(struct ieee80211_hw *hw)
  1267. {
  1268. struct rtl_priv *rtlpriv = rtl_priv(hw);
  1269. struct rtl_pci *rtlpci = rtl_pcidev(rtl_pcipriv(hw));
  1270. rtl92ee_clear_interrupt(hw);/*clear it here first*/
  1271. rtl_write_dword(rtlpriv, REG_HIMR, rtlpci->irq_mask[0] & 0xFFFFFFFF);
  1272. rtl_write_dword(rtlpriv, REG_HIMRE, rtlpci->irq_mask[1] & 0xFFFFFFFF);
  1273. rtlpci->irq_enabled = true;
  1274. }
  1275. void rtl92ee_disable_interrupt(struct ieee80211_hw *hw)
  1276. {
  1277. struct rtl_priv *rtlpriv = rtl_priv(hw);
  1278. struct rtl_pci *rtlpci = rtl_pcidev(rtl_pcipriv(hw));
  1279. rtl_write_dword(rtlpriv, REG_HIMR, IMR_DISABLED);
  1280. rtl_write_dword(rtlpriv, REG_HIMRE, IMR_DISABLED);
  1281. rtlpci->irq_enabled = false;
  1282. /*synchronize_irq(rtlpci->pdev->irq);*/
  1283. }
  1284. static void _rtl92ee_poweroff_adapter(struct ieee80211_hw *hw)
  1285. {
  1286. struct rtl_priv *rtlpriv = rtl_priv(hw);
  1287. struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw));
  1288. u8 u1b_tmp;
  1289. rtlhal->mac_func_enable = false;
  1290. RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD, "POWER OFF adapter\n");
  1291. /* Run LPS WL RFOFF flow */
  1292. rtl_hal_pwrseqcmdparsing(rtlpriv, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK,
  1293. PWR_INTF_PCI_MSK, RTL8192E_NIC_LPS_ENTER_FLOW);
  1294. /* turn off RF */
  1295. rtl_write_byte(rtlpriv, REG_RF_CTRL, 0x00);
  1296. /* ==== Reset digital sequence ====== */
  1297. if ((rtl_read_byte(rtlpriv, REG_MCUFWDL) & BIT(7)) && rtlhal->fw_ready)
  1298. rtl92ee_firmware_selfreset(hw);
  1299. /* Reset MCU */
  1300. u1b_tmp = rtl_read_byte(rtlpriv, REG_SYS_FUNC_EN + 1);
  1301. rtl_write_byte(rtlpriv, REG_SYS_FUNC_EN + 1, (u1b_tmp & (~BIT(2))));
  1302. /* reset MCU ready status */
  1303. rtl_write_byte(rtlpriv, REG_MCUFWDL, 0x00);
  1304. /* HW card disable configuration. */
  1305. rtl_hal_pwrseqcmdparsing(rtlpriv, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK,
  1306. PWR_INTF_PCI_MSK, RTL8192E_NIC_DISABLE_FLOW);
  1307. /* Reset MCU IO Wrapper */
  1308. u1b_tmp = rtl_read_byte(rtlpriv, REG_RSV_CTRL + 1);
  1309. rtl_write_byte(rtlpriv, REG_RSV_CTRL + 1, (u1b_tmp & (~BIT(0))));
  1310. u1b_tmp = rtl_read_byte(rtlpriv, REG_RSV_CTRL + 1);
  1311. rtl_write_byte(rtlpriv, REG_RSV_CTRL + 1, (u1b_tmp | BIT(0)));
  1312. /* lock ISO/CLK/Power control register */
  1313. rtl_write_byte(rtlpriv, REG_RSV_CTRL, 0x0E);
  1314. }
  1315. void rtl92ee_card_disable(struct ieee80211_hw *hw)
  1316. {
  1317. struct rtl_priv *rtlpriv = rtl_priv(hw);
  1318. struct rtl_ps_ctl *ppsc = rtl_psc(rtl_priv(hw));
  1319. struct rtl_mac *mac = rtl_mac(rtl_priv(hw));
  1320. enum nl80211_iftype opmode;
  1321. RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD, "RTL8192ee card disable\n");
  1322. RT_SET_PS_LEVEL(ppsc, RT_RF_OFF_LEVL_HALT_NIC);
  1323. mac->link_state = MAC80211_NOLINK;
  1324. opmode = NL80211_IFTYPE_UNSPECIFIED;
  1325. _rtl92ee_set_media_status(hw, opmode);
  1326. if (rtlpriv->rtlhal.driver_is_goingto_unload ||
  1327. ppsc->rfoff_reason > RF_CHANGE_BY_PS)
  1328. rtlpriv->cfg->ops->led_control(hw, LED_CTL_POWER_OFF);
  1329. _rtl92ee_poweroff_adapter(hw);
  1330. /* after power off we should do iqk again */
  1331. rtlpriv->phy.iqk_initialized = false;
  1332. }
  1333. void rtl92ee_interrupt_recognized(struct ieee80211_hw *hw,
  1334. u32 *p_inta, u32 *p_intb)
  1335. {
  1336. struct rtl_priv *rtlpriv = rtl_priv(hw);
  1337. struct rtl_pci *rtlpci = rtl_pcidev(rtl_pcipriv(hw));
  1338. *p_inta = rtl_read_dword(rtlpriv, ISR) & rtlpci->irq_mask[0];
  1339. rtl_write_dword(rtlpriv, ISR, *p_inta);
  1340. *p_intb = rtl_read_dword(rtlpriv, REG_HISRE) & rtlpci->irq_mask[1];
  1341. rtl_write_dword(rtlpriv, REG_HISRE, *p_intb);
  1342. }
  1343. void rtl92ee_set_beacon_related_registers(struct ieee80211_hw *hw)
  1344. {
  1345. struct rtl_priv *rtlpriv = rtl_priv(hw);
  1346. struct rtl_mac *mac = rtl_mac(rtl_priv(hw));
  1347. struct rtl_pci *rtlpci = rtl_pcidev(rtl_pcipriv(hw));
  1348. u16 bcn_interval, atim_window;
  1349. bcn_interval = mac->beacon_interval;
  1350. atim_window = 2; /*FIX MERGE */
  1351. rtl92ee_disable_interrupt(hw);
  1352. rtl_write_word(rtlpriv, REG_ATIMWND, atim_window);
  1353. rtl_write_word(rtlpriv, REG_BCN_INTERVAL, bcn_interval);
  1354. rtl_write_word(rtlpriv, REG_BCNTCFG, 0x660f);
  1355. rtl_write_byte(rtlpriv, REG_RXTSF_OFFSET_CCK, 0x18);
  1356. rtl_write_byte(rtlpriv, REG_RXTSF_OFFSET_OFDM, 0x18);
  1357. rtl_write_byte(rtlpriv, 0x606, 0x30);
  1358. rtlpci->reg_bcn_ctrl_val |= BIT(3);
  1359. rtl_write_byte(rtlpriv, REG_BCN_CTRL, (u8)rtlpci->reg_bcn_ctrl_val);
  1360. }
  1361. void rtl92ee_set_beacon_interval(struct ieee80211_hw *hw)
  1362. {
  1363. struct rtl_priv *rtlpriv = rtl_priv(hw);
  1364. struct rtl_mac *mac = rtl_mac(rtl_priv(hw));
  1365. u16 bcn_interval = mac->beacon_interval;
  1366. RT_TRACE(rtlpriv, COMP_BEACON, DBG_DMESG,
  1367. "beacon_interval:%d\n", bcn_interval);
  1368. rtl_write_word(rtlpriv, REG_BCN_INTERVAL, bcn_interval);
  1369. }
  1370. void rtl92ee_update_interrupt_mask(struct ieee80211_hw *hw,
  1371. u32 add_msr, u32 rm_msr)
  1372. {
  1373. struct rtl_priv *rtlpriv = rtl_priv(hw);
  1374. struct rtl_pci *rtlpci = rtl_pcidev(rtl_pcipriv(hw));
  1375. RT_TRACE(rtlpriv, COMP_INTR, DBG_LOUD,
  1376. "add_msr:%x, rm_msr:%x\n", add_msr, rm_msr);
  1377. if (add_msr)
  1378. rtlpci->irq_mask[0] |= add_msr;
  1379. if (rm_msr)
  1380. rtlpci->irq_mask[0] &= (~rm_msr);
  1381. rtl92ee_disable_interrupt(hw);
  1382. rtl92ee_enable_interrupt(hw);
  1383. }
  1384. static u8 _rtl92ee_get_chnl_group(u8 chnl)
  1385. {
  1386. u8 group = 0;
  1387. if (chnl <= 14) {
  1388. if (1 <= chnl && chnl <= 2)
  1389. group = 0;
  1390. else if (3 <= chnl && chnl <= 5)
  1391. group = 1;
  1392. else if (6 <= chnl && chnl <= 8)
  1393. group = 2;
  1394. else if (9 <= chnl && chnl <= 11)
  1395. group = 3;
  1396. else if (12 <= chnl && chnl <= 14)
  1397. group = 4;
  1398. } else {
  1399. if (36 <= chnl && chnl <= 42)
  1400. group = 0;
  1401. else if (44 <= chnl && chnl <= 48)
  1402. group = 1;
  1403. else if (50 <= chnl && chnl <= 58)
  1404. group = 2;
  1405. else if (60 <= chnl && chnl <= 64)
  1406. group = 3;
  1407. else if (100 <= chnl && chnl <= 106)
  1408. group = 4;
  1409. else if (108 <= chnl && chnl <= 114)
  1410. group = 5;
  1411. else if (116 <= chnl && chnl <= 122)
  1412. group = 6;
  1413. else if (124 <= chnl && chnl <= 130)
  1414. group = 7;
  1415. else if (132 <= chnl && chnl <= 138)
  1416. group = 8;
  1417. else if (140 <= chnl && chnl <= 144)
  1418. group = 9;
  1419. else if (149 <= chnl && chnl <= 155)
  1420. group = 10;
  1421. else if (157 <= chnl && chnl <= 161)
  1422. group = 11;
  1423. else if (165 <= chnl && chnl <= 171)
  1424. group = 12;
  1425. else if (173 <= chnl && chnl <= 177)
  1426. group = 13;
  1427. }
  1428. return group;
  1429. }
  1430. static void _rtl8192ee_read_power_value_fromprom(struct ieee80211_hw *hw,
  1431. struct txpower_info_2g *pwr2g,
  1432. struct txpower_info_5g *pwr5g,
  1433. bool autoload_fail, u8 *hwinfo)
  1434. {
  1435. struct rtl_priv *rtlpriv = rtl_priv(hw);
  1436. u32 rf, addr = EEPROM_TX_PWR_INX, group, i = 0;
  1437. RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD,
  1438. "hal_ReadPowerValueFromPROM92E(): PROMContent[0x%x]=0x%x\n",
  1439. (addr + 1), hwinfo[addr + 1]);
  1440. if (0xFF == hwinfo[addr+1]) /*YJ,add,120316*/
  1441. autoload_fail = true;
  1442. if (autoload_fail) {
  1443. RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD,
  1444. "auto load fail : Use Default value!\n");
  1445. for (rf = 0 ; rf < MAX_RF_PATH ; rf++) {
  1446. /* 2.4G default value */
  1447. for (group = 0 ; group < MAX_CHNL_GROUP_24G; group++) {
  1448. pwr2g->index_cck_base[rf][group] = 0x2D;
  1449. pwr2g->index_bw40_base[rf][group] = 0x2D;
  1450. }
  1451. for (i = 0; i < MAX_TX_COUNT; i++) {
  1452. if (i == 0) {
  1453. pwr2g->bw20_diff[rf][0] = 0x02;
  1454. pwr2g->ofdm_diff[rf][0] = 0x04;
  1455. } else {
  1456. pwr2g->bw20_diff[rf][i] = 0xFE;
  1457. pwr2g->bw40_diff[rf][i] = 0xFE;
  1458. pwr2g->cck_diff[rf][i] = 0xFE;
  1459. pwr2g->ofdm_diff[rf][i] = 0xFE;
  1460. }
  1461. }
  1462. /*5G default value*/
  1463. for (group = 0 ; group < MAX_CHNL_GROUP_5G; group++)
  1464. pwr5g->index_bw40_base[rf][group] = 0x2A;
  1465. for (i = 0; i < MAX_TX_COUNT; i++) {
  1466. if (i == 0) {
  1467. pwr5g->ofdm_diff[rf][0] = 0x04;
  1468. pwr5g->bw20_diff[rf][0] = 0x00;
  1469. pwr5g->bw80_diff[rf][0] = 0xFE;
  1470. pwr5g->bw160_diff[rf][0] = 0xFE;
  1471. } else {
  1472. pwr5g->ofdm_diff[rf][0] = 0xFE;
  1473. pwr5g->bw20_diff[rf][0] = 0xFE;
  1474. pwr5g->bw40_diff[rf][0] = 0xFE;
  1475. pwr5g->bw80_diff[rf][0] = 0xFE;
  1476. pwr5g->bw160_diff[rf][0] = 0xFE;
  1477. }
  1478. }
  1479. }
  1480. return;
  1481. }
  1482. rtl_priv(hw)->efuse.txpwr_fromeprom = true;
  1483. for (rf = 0 ; rf < MAX_RF_PATH ; rf++) {
  1484. /*2.4G default value*/
  1485. for (group = 0 ; group < MAX_CHNL_GROUP_24G; group++) {
  1486. pwr2g->index_cck_base[rf][group] = hwinfo[addr++];
  1487. if (pwr2g->index_cck_base[rf][group] == 0xFF)
  1488. pwr2g->index_cck_base[rf][group] = 0x2D;
  1489. }
  1490. for (group = 0 ; group < MAX_CHNL_GROUP_24G - 1; group++) {
  1491. pwr2g->index_bw40_base[rf][group] = hwinfo[addr++];
  1492. if (pwr2g->index_bw40_base[rf][group] == 0xFF)
  1493. pwr2g->index_bw40_base[rf][group] = 0x2D;
  1494. }
  1495. for (i = 0; i < MAX_TX_COUNT; i++) {
  1496. if (i == 0) {
  1497. pwr2g->bw40_diff[rf][i] = 0;
  1498. if (hwinfo[addr] == 0xFF) {
  1499. pwr2g->bw20_diff[rf][i] = 0x02;
  1500. } else {
  1501. pwr2g->bw20_diff[rf][i] = (hwinfo[addr]
  1502. & 0xf0) >> 4;
  1503. if (pwr2g->bw20_diff[rf][i] & BIT(3))
  1504. pwr2g->bw20_diff[rf][i] |= 0xF0;
  1505. }
  1506. if (hwinfo[addr] == 0xFF) {
  1507. pwr2g->ofdm_diff[rf][i] = 0x04;
  1508. } else {
  1509. pwr2g->ofdm_diff[rf][i] = (hwinfo[addr]
  1510. & 0x0f);
  1511. if (pwr2g->ofdm_diff[rf][i] & BIT(3))
  1512. pwr2g->ofdm_diff[rf][i] |= 0xF0;
  1513. }
  1514. pwr2g->cck_diff[rf][i] = 0;
  1515. addr++;
  1516. } else {
  1517. if (hwinfo[addr] == 0xFF) {
  1518. pwr2g->bw40_diff[rf][i] = 0xFE;
  1519. } else {
  1520. pwr2g->bw40_diff[rf][i] = (hwinfo[addr]
  1521. & 0xf0) >> 4;
  1522. if (pwr2g->bw40_diff[rf][i] & BIT(3))
  1523. pwr2g->bw40_diff[rf][i] |= 0xF0;
  1524. }
  1525. if (hwinfo[addr] == 0xFF) {
  1526. pwr2g->bw20_diff[rf][i] = 0xFE;
  1527. } else {
  1528. pwr2g->bw20_diff[rf][i] = (hwinfo[addr]
  1529. & 0x0f);
  1530. if (pwr2g->bw20_diff[rf][i] & BIT(3))
  1531. pwr2g->bw20_diff[rf][i] |= 0xF0;
  1532. }
  1533. addr++;
  1534. if (hwinfo[addr] == 0xFF) {
  1535. pwr2g->ofdm_diff[rf][i] = 0xFE;
  1536. } else {
  1537. pwr2g->ofdm_diff[rf][i] = (hwinfo[addr]
  1538. & 0xf0) >> 4;
  1539. if (pwr2g->ofdm_diff[rf][i] & BIT(3))
  1540. pwr2g->ofdm_diff[rf][i] |= 0xF0;
  1541. }
  1542. if (hwinfo[addr] == 0xFF) {
  1543. pwr2g->cck_diff[rf][i] = 0xFE;
  1544. } else {
  1545. pwr2g->cck_diff[rf][i] = (hwinfo[addr]
  1546. & 0x0f);
  1547. if (pwr2g->cck_diff[rf][i] & BIT(3))
  1548. pwr2g->cck_diff[rf][i] |= 0xF0;
  1549. }
  1550. addr++;
  1551. }
  1552. }
  1553. /*5G default value*/
  1554. for (group = 0 ; group < MAX_CHNL_GROUP_5G; group++) {
  1555. pwr5g->index_bw40_base[rf][group] = hwinfo[addr++];
  1556. if (pwr5g->index_bw40_base[rf][group] == 0xFF)
  1557. pwr5g->index_bw40_base[rf][group] = 0xFE;
  1558. }
  1559. for (i = 0; i < MAX_TX_COUNT; i++) {
  1560. if (i == 0) {
  1561. pwr5g->bw40_diff[rf][i] = 0;
  1562. if (hwinfo[addr] == 0xFF) {
  1563. pwr5g->bw20_diff[rf][i] = 0;
  1564. } else {
  1565. pwr5g->bw20_diff[rf][0] = (hwinfo[addr]
  1566. & 0xf0) >> 4;
  1567. if (pwr5g->bw20_diff[rf][i] & BIT(3))
  1568. pwr5g->bw20_diff[rf][i] |= 0xF0;
  1569. }
  1570. if (hwinfo[addr] == 0xFF) {
  1571. pwr5g->ofdm_diff[rf][i] = 0x04;
  1572. } else {
  1573. pwr5g->ofdm_diff[rf][0] = (hwinfo[addr]
  1574. & 0x0f);
  1575. if (pwr5g->ofdm_diff[rf][i] & BIT(3))
  1576. pwr5g->ofdm_diff[rf][i] |= 0xF0;
  1577. }
  1578. addr++;
  1579. } else {
  1580. if (hwinfo[addr] == 0xFF) {
  1581. pwr5g->bw40_diff[rf][i] = 0xFE;
  1582. } else {
  1583. pwr5g->bw40_diff[rf][i] = (hwinfo[addr]
  1584. & 0xf0) >> 4;
  1585. if (pwr5g->bw40_diff[rf][i] & BIT(3))
  1586. pwr5g->bw40_diff[rf][i] |= 0xF0;
  1587. }
  1588. if (hwinfo[addr] == 0xFF) {
  1589. pwr5g->bw20_diff[rf][i] = 0xFE;
  1590. } else {
  1591. pwr5g->bw20_diff[rf][i] = (hwinfo[addr]
  1592. & 0x0f);
  1593. if (pwr5g->bw20_diff[rf][i] & BIT(3))
  1594. pwr5g->bw20_diff[rf][i] |= 0xF0;
  1595. }
  1596. addr++;
  1597. }
  1598. }
  1599. if (hwinfo[addr] == 0xFF) {
  1600. pwr5g->ofdm_diff[rf][1] = 0xFE;
  1601. pwr5g->ofdm_diff[rf][2] = 0xFE;
  1602. } else {
  1603. pwr5g->ofdm_diff[rf][1] = (hwinfo[addr] & 0xf0) >> 4;
  1604. pwr5g->ofdm_diff[rf][2] = (hwinfo[addr] & 0x0f);
  1605. }
  1606. addr++;
  1607. if (hwinfo[addr] == 0xFF)
  1608. pwr5g->ofdm_diff[rf][3] = 0xFE;
  1609. else
  1610. pwr5g->ofdm_diff[rf][3] = (hwinfo[addr] & 0x0f);
  1611. addr++;
  1612. for (i = 1; i < MAX_TX_COUNT; i++) {
  1613. if (pwr5g->ofdm_diff[rf][i] == 0xFF)
  1614. pwr5g->ofdm_diff[rf][i] = 0xFE;
  1615. else if (pwr5g->ofdm_diff[rf][i] & BIT(3))
  1616. pwr5g->ofdm_diff[rf][i] |= 0xF0;
  1617. }
  1618. for (i = 0; i < MAX_TX_COUNT; i++) {
  1619. if (hwinfo[addr] == 0xFF) {
  1620. pwr5g->bw80_diff[rf][i] = 0xFE;
  1621. } else {
  1622. pwr5g->bw80_diff[rf][i] = (hwinfo[addr] & 0xf0)
  1623. >> 4;
  1624. if (pwr5g->bw80_diff[rf][i] & BIT(3))
  1625. pwr5g->bw80_diff[rf][i] |= 0xF0;
  1626. }
  1627. if (hwinfo[addr] == 0xFF) {
  1628. pwr5g->bw160_diff[rf][i] = 0xFE;
  1629. } else {
  1630. pwr5g->bw160_diff[rf][i] =
  1631. (hwinfo[addr] & 0x0f);
  1632. if (pwr5g->bw160_diff[rf][i] & BIT(3))
  1633. pwr5g->bw160_diff[rf][i] |= 0xF0;
  1634. }
  1635. addr++;
  1636. }
  1637. }
  1638. }
  1639. static void _rtl92ee_read_txpower_info_from_hwpg(struct ieee80211_hw *hw,
  1640. bool autoload_fail, u8 *hwinfo)
  1641. {
  1642. struct rtl_priv *rtlpriv = rtl_priv(hw);
  1643. struct rtl_efuse *efu = rtl_efuse(rtl_priv(hw));
  1644. struct txpower_info_2g pwr2g;
  1645. struct txpower_info_5g pwr5g;
  1646. u8 channel5g[CHANNEL_MAX_NUMBER_5G] = {
  1647. 36, 38, 40, 42, 44, 46, 48, 50, 52, 54,
  1648. 56, 58, 60, 62, 64, 100, 102, 104, 106,
  1649. 108, 110, 112, 114, 116, 118, 120, 122,
  1650. 124, 126, 128, 130, 132, 134, 136, 138,
  1651. 140, 142, 144, 149, 151, 153, 155, 157,
  1652. 159, 161, 163, 165, 167, 168, 169, 171,
  1653. 173, 175, 177
  1654. };
  1655. u8 channel5g_80m[CHANNEL_MAX_NUMBER_5G_80M] = {
  1656. 42, 58, 106, 122, 138, 155, 171
  1657. };
  1658. u8 rf, idx;
  1659. u8 i;
  1660. _rtl8192ee_read_power_value_fromprom(hw, &pwr2g, &pwr5g,
  1661. autoload_fail, hwinfo);
  1662. for (rf = 0; rf < MAX_RF_PATH; rf++) {
  1663. for (i = 0; i < 14; i++) {
  1664. idx = _rtl92ee_get_chnl_group(i + 1);
  1665. if (i == CHANNEL_MAX_NUMBER_2G - 1) {
  1666. efu->txpwrlevel_cck[rf][i] =
  1667. pwr2g.index_cck_base[rf][5];
  1668. efu->txpwrlevel_ht40_1s[rf][i] =
  1669. pwr2g.index_bw40_base[rf][idx];
  1670. } else {
  1671. efu->txpwrlevel_cck[rf][i] =
  1672. pwr2g.index_cck_base[rf][idx];
  1673. efu->txpwrlevel_ht40_1s[rf][i] =
  1674. pwr2g.index_bw40_base[rf][idx];
  1675. }
  1676. }
  1677. for (i = 0; i < CHANNEL_MAX_NUMBER_5G; i++) {
  1678. idx = _rtl92ee_get_chnl_group(channel5g[i]);
  1679. efu->txpwr_5g_bw40base[rf][i] =
  1680. pwr5g.index_bw40_base[rf][idx];
  1681. }
  1682. for (i = 0; i < CHANNEL_MAX_NUMBER_5G_80M; i++) {
  1683. u8 upper, lower;
  1684. idx = _rtl92ee_get_chnl_group(channel5g_80m[i]);
  1685. upper = pwr5g.index_bw40_base[rf][idx];
  1686. lower = pwr5g.index_bw40_base[rf][idx + 1];
  1687. efu->txpwr_5g_bw80base[rf][i] = (upper + lower) / 2;
  1688. }
  1689. for (i = 0; i < MAX_TX_COUNT; i++) {
  1690. efu->txpwr_cckdiff[rf][i] = pwr2g.cck_diff[rf][i];
  1691. efu->txpwr_legacyhtdiff[rf][i] = pwr2g.ofdm_diff[rf][i];
  1692. efu->txpwr_ht20diff[rf][i] = pwr2g.bw20_diff[rf][i];
  1693. efu->txpwr_ht40diff[rf][i] = pwr2g.bw40_diff[rf][i];
  1694. efu->txpwr_5g_ofdmdiff[rf][i] = pwr5g.ofdm_diff[rf][i];
  1695. efu->txpwr_5g_bw20diff[rf][i] = pwr5g.bw20_diff[rf][i];
  1696. efu->txpwr_5g_bw40diff[rf][i] = pwr5g.bw40_diff[rf][i];
  1697. efu->txpwr_5g_bw80diff[rf][i] = pwr5g.bw80_diff[rf][i];
  1698. }
  1699. }
  1700. if (!autoload_fail)
  1701. efu->eeprom_thermalmeter = hwinfo[EEPROM_THERMAL_METER_92E];
  1702. else
  1703. efu->eeprom_thermalmeter = EEPROM_DEFAULT_THERMALMETER;
  1704. if (efu->eeprom_thermalmeter == 0xff || autoload_fail) {
  1705. efu->apk_thermalmeterignore = true;
  1706. efu->eeprom_thermalmeter = EEPROM_DEFAULT_THERMALMETER;
  1707. }
  1708. efu->thermalmeter[0] = efu->eeprom_thermalmeter;
  1709. RTPRINT(rtlpriv, FINIT, INIT_TXPOWER,
  1710. "thermalmeter = 0x%x\n", efu->eeprom_thermalmeter);
  1711. if (!autoload_fail) {
  1712. efu->eeprom_regulatory = hwinfo[EEPROM_RF_BOARD_OPTION_92E]
  1713. & 0x07;
  1714. if (hwinfo[EEPROM_RF_BOARD_OPTION_92E] == 0xFF)
  1715. efu->eeprom_regulatory = 0;
  1716. } else {
  1717. efu->eeprom_regulatory = 0;
  1718. }
  1719. RTPRINT(rtlpriv, FINIT, INIT_TXPOWER,
  1720. "eeprom_regulatory = 0x%x\n", efu->eeprom_regulatory);
  1721. }
  1722. static void _rtl92ee_read_adapter_info(struct ieee80211_hw *hw)
  1723. {
  1724. struct rtl_priv *rtlpriv = rtl_priv(hw);
  1725. struct rtl_efuse *rtlefuse = rtl_efuse(rtl_priv(hw));
  1726. struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw));
  1727. u16 i, usvalue;
  1728. u8 hwinfo[HWSET_MAX_SIZE];
  1729. u16 eeprom_id;
  1730. if (rtlefuse->epromtype == EEPROM_BOOT_EFUSE) {
  1731. rtl_efuse_shadow_map_update(hw);
  1732. memcpy(hwinfo, &rtlefuse->efuse_map[EFUSE_INIT_MAP][0],
  1733. HWSET_MAX_SIZE);
  1734. } else if (rtlefuse->epromtype == EEPROM_93C46) {
  1735. RT_TRACE(rtlpriv, COMP_ERR, DBG_EMERG,
  1736. "RTL819X Not boot from eeprom, check it !!");
  1737. return;
  1738. } else {
  1739. RT_TRACE(rtlpriv, COMP_ERR, DBG_EMERG,
  1740. "boot from neither eeprom nor efuse, check it !!");
  1741. return;
  1742. }
  1743. RT_PRINT_DATA(rtlpriv, COMP_INIT, DBG_DMESG, "MAP\n",
  1744. hwinfo, HWSET_MAX_SIZE);
  1745. eeprom_id = *((u16 *)&hwinfo[0]);
  1746. if (eeprom_id != RTL8192E_EEPROM_ID) {
  1747. RT_TRACE(rtlpriv, COMP_ERR, DBG_WARNING,
  1748. "EEPROM ID(%#x) is invalid!!\n", eeprom_id);
  1749. rtlefuse->autoload_failflag = true;
  1750. } else {
  1751. RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD, "Autoload OK\n");
  1752. rtlefuse->autoload_failflag = false;
  1753. }
  1754. if (rtlefuse->autoload_failflag)
  1755. return;
  1756. /*VID DID SVID SDID*/
  1757. rtlefuse->eeprom_vid = *(u16 *)&hwinfo[EEPROM_VID];
  1758. rtlefuse->eeprom_did = *(u16 *)&hwinfo[EEPROM_DID];
  1759. rtlefuse->eeprom_svid = *(u16 *)&hwinfo[EEPROM_SVID];
  1760. rtlefuse->eeprom_smid = *(u16 *)&hwinfo[EEPROM_SMID];
  1761. RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD, "EEPROMId = 0x%4x\n", eeprom_id);
  1762. RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD,
  1763. "EEPROM VID = 0x%4x\n", rtlefuse->eeprom_vid);
  1764. RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD,
  1765. "EEPROM DID = 0x%4x\n", rtlefuse->eeprom_did);
  1766. RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD,
  1767. "EEPROM SVID = 0x%4x\n", rtlefuse->eeprom_svid);
  1768. RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD,
  1769. "EEPROM SMID = 0x%4x\n", rtlefuse->eeprom_smid);
  1770. /*customer ID*/
  1771. rtlefuse->eeprom_oemid = *(u8 *)&hwinfo[EEPROM_CUSTOMER_ID];
  1772. if (rtlefuse->eeprom_oemid == 0xFF)
  1773. rtlefuse->eeprom_oemid = 0;
  1774. RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD,
  1775. "EEPROM Customer ID: 0x%2x\n", rtlefuse->eeprom_oemid);
  1776. /*EEPROM version*/
  1777. rtlefuse->eeprom_version = *(u8 *)&hwinfo[EEPROM_VERSION];
  1778. /*mac address*/
  1779. for (i = 0; i < 6; i += 2) {
  1780. usvalue = *(u16 *)&hwinfo[EEPROM_MAC_ADDR + i];
  1781. *((u16 *)(&rtlefuse->dev_addr[i])) = usvalue;
  1782. }
  1783. RT_TRACE(rtlpriv, COMP_INIT, DBG_DMESG,
  1784. "dev_addr: %pM\n", rtlefuse->dev_addr);
  1785. /*channel plan */
  1786. rtlefuse->eeprom_channelplan = *(u8 *)&hwinfo[EEPROM_CHANNELPLAN];
  1787. /* set channel paln to world wide 13 */
  1788. rtlefuse->channel_plan = COUNTRY_CODE_WORLD_WIDE_13;
  1789. /*tx power*/
  1790. _rtl92ee_read_txpower_info_from_hwpg(hw, rtlefuse->autoload_failflag,
  1791. hwinfo);
  1792. rtl92ee_read_bt_coexist_info_from_hwpg(hw, rtlefuse->autoload_failflag,
  1793. hwinfo);
  1794. /*board type*/
  1795. rtlefuse->board_type = (((*(u8 *)&hwinfo[EEPROM_RF_BOARD_OPTION_92E])
  1796. & 0xE0) >> 5);
  1797. if ((*(u8 *)&hwinfo[EEPROM_RF_BOARD_OPTION_92E]) == 0xFF)
  1798. rtlefuse->board_type = 0;
  1799. rtlhal->board_type = rtlefuse->board_type;
  1800. /*parse xtal*/
  1801. rtlefuse->crystalcap = hwinfo[EEPROM_XTAL_92E];
  1802. if (hwinfo[EEPROM_XTAL_92E] == 0xFF)
  1803. rtlefuse->crystalcap = 0x20;
  1804. /*antenna diversity*/
  1805. rtlefuse->antenna_div_type = NO_ANTDIV;
  1806. rtlefuse->antenna_div_cfg = 0;
  1807. if (rtlhal->oem_id == RT_CID_DEFAULT) {
  1808. switch (rtlefuse->eeprom_oemid) {
  1809. case EEPROM_CID_DEFAULT:
  1810. if (rtlefuse->eeprom_did == 0x818B) {
  1811. if ((rtlefuse->eeprom_svid == 0x10EC) &&
  1812. (rtlefuse->eeprom_smid == 0x001B))
  1813. rtlhal->oem_id = RT_CID_819X_LENOVO;
  1814. } else {
  1815. rtlhal->oem_id = RT_CID_DEFAULT;
  1816. }
  1817. break;
  1818. default:
  1819. rtlhal->oem_id = RT_CID_DEFAULT;
  1820. break;
  1821. }
  1822. }
  1823. }
  1824. static void _rtl92ee_hal_customized_behavior(struct ieee80211_hw *hw)
  1825. {
  1826. struct rtl_priv *rtlpriv = rtl_priv(hw);
  1827. struct rtl_pci_priv *pcipriv = rtl_pcipriv(hw);
  1828. struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw));
  1829. pcipriv->ledctl.led_opendrain = true;
  1830. RT_TRACE(rtlpriv, COMP_INIT, DBG_DMESG,
  1831. "RT Customized ID: 0x%02X\n", rtlhal->oem_id);
  1832. }
  1833. void rtl92ee_read_eeprom_info(struct ieee80211_hw *hw)
  1834. {
  1835. struct rtl_priv *rtlpriv = rtl_priv(hw);
  1836. struct rtl_efuse *rtlefuse = rtl_efuse(rtl_priv(hw));
  1837. struct rtl_phy *rtlphy = &rtlpriv->phy;
  1838. struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw));
  1839. u8 tmp_u1b;
  1840. rtlhal->version = _rtl92ee_read_chip_version(hw);
  1841. if (get_rf_type(rtlphy) == RF_1T1R) {
  1842. rtlpriv->dm.rfpath_rxenable[0] = true;
  1843. } else {
  1844. rtlpriv->dm.rfpath_rxenable[0] = true;
  1845. rtlpriv->dm.rfpath_rxenable[1] = true;
  1846. }
  1847. RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD, "VersionID = 0x%4x\n",
  1848. rtlhal->version);
  1849. tmp_u1b = rtl_read_byte(rtlpriv, REG_9346CR);
  1850. if (tmp_u1b & BIT(4)) {
  1851. RT_TRACE(rtlpriv, COMP_INIT, DBG_DMESG, "Boot from EEPROM\n");
  1852. rtlefuse->epromtype = EEPROM_93C46;
  1853. } else {
  1854. RT_TRACE(rtlpriv, COMP_INIT, DBG_DMESG, "Boot from EFUSE\n");
  1855. rtlefuse->epromtype = EEPROM_BOOT_EFUSE;
  1856. }
  1857. if (tmp_u1b & BIT(5)) {
  1858. RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD, "Autoload OK\n");
  1859. rtlefuse->autoload_failflag = false;
  1860. _rtl92ee_read_adapter_info(hw);
  1861. } else {
  1862. RT_TRACE(rtlpriv, COMP_ERR, DBG_EMERG, "Autoload ERR!!\n");
  1863. }
  1864. _rtl92ee_hal_customized_behavior(hw);
  1865. rtlphy->rfpath_rx_enable[0] = true;
  1866. if (rtlphy->rf_type == RF_2T2R)
  1867. rtlphy->rfpath_rx_enable[1] = true;
  1868. }
  1869. static u8 _rtl92ee_mrate_idx_to_arfr_id(struct ieee80211_hw *hw, u8 rate_index)
  1870. {
  1871. u8 ret = 0;
  1872. switch (rate_index) {
  1873. case RATR_INX_WIRELESS_NGB:
  1874. ret = 0;
  1875. break;
  1876. case RATR_INX_WIRELESS_N:
  1877. case RATR_INX_WIRELESS_NG:
  1878. ret = 4;
  1879. break;
  1880. case RATR_INX_WIRELESS_NB:
  1881. ret = 2;
  1882. break;
  1883. case RATR_INX_WIRELESS_GB:
  1884. ret = 6;
  1885. break;
  1886. case RATR_INX_WIRELESS_G:
  1887. ret = 7;
  1888. break;
  1889. case RATR_INX_WIRELESS_B:
  1890. ret = 8;
  1891. break;
  1892. default:
  1893. ret = 0;
  1894. break;
  1895. }
  1896. return ret;
  1897. }
  1898. static void rtl92ee_update_hal_rate_mask(struct ieee80211_hw *hw,
  1899. struct ieee80211_sta *sta,
  1900. u8 rssi_level)
  1901. {
  1902. struct rtl_priv *rtlpriv = rtl_priv(hw);
  1903. struct rtl_phy *rtlphy = &rtlpriv->phy;
  1904. struct rtl_mac *mac = rtl_mac(rtl_priv(hw));
  1905. struct rtl_sta_info *sta_entry = NULL;
  1906. u32 ratr_bitmap;
  1907. u8 ratr_index;
  1908. u8 curtxbw_40mhz = (sta->ht_cap.cap & IEEE80211_HT_CAP_SUP_WIDTH_20_40)
  1909. ? 1 : 0;
  1910. u8 b_curshortgi_40mhz = (sta->ht_cap.cap & IEEE80211_HT_CAP_SGI_40) ?
  1911. 1 : 0;
  1912. u8 b_curshortgi_20mhz = (sta->ht_cap.cap & IEEE80211_HT_CAP_SGI_20) ?
  1913. 1 : 0;
  1914. enum wireless_mode wirelessmode = 0;
  1915. bool b_shortgi = false;
  1916. u8 rate_mask[7] = {0};
  1917. u8 macid = 0;
  1918. /*u8 mimo_ps = IEEE80211_SMPS_OFF;*/
  1919. sta_entry = (struct rtl_sta_info *)sta->drv_priv;
  1920. wirelessmode = sta_entry->wireless_mode;
  1921. if (mac->opmode == NL80211_IFTYPE_STATION ||
  1922. mac->opmode == NL80211_IFTYPE_MESH_POINT)
  1923. curtxbw_40mhz = mac->bw_40;
  1924. else if (mac->opmode == NL80211_IFTYPE_AP ||
  1925. mac->opmode == NL80211_IFTYPE_ADHOC)
  1926. macid = sta->aid + 1;
  1927. ratr_bitmap = sta->supp_rates[0];
  1928. if (mac->opmode == NL80211_IFTYPE_ADHOC)
  1929. ratr_bitmap = 0xfff;
  1930. ratr_bitmap |= (sta->ht_cap.mcs.rx_mask[1] << 20 |
  1931. sta->ht_cap.mcs.rx_mask[0] << 12);
  1932. switch (wirelessmode) {
  1933. case WIRELESS_MODE_B:
  1934. ratr_index = RATR_INX_WIRELESS_B;
  1935. if (ratr_bitmap & 0x0000000c)
  1936. ratr_bitmap &= 0x0000000d;
  1937. else
  1938. ratr_bitmap &= 0x0000000f;
  1939. break;
  1940. case WIRELESS_MODE_G:
  1941. ratr_index = RATR_INX_WIRELESS_GB;
  1942. if (rssi_level == 1)
  1943. ratr_bitmap &= 0x00000f00;
  1944. else if (rssi_level == 2)
  1945. ratr_bitmap &= 0x00000ff0;
  1946. else
  1947. ratr_bitmap &= 0x00000ff5;
  1948. break;
  1949. case WIRELESS_MODE_N_24G:
  1950. if (curtxbw_40mhz)
  1951. ratr_index = RATR_INX_WIRELESS_NGB;
  1952. else
  1953. ratr_index = RATR_INX_WIRELESS_NB;
  1954. if (rtlphy->rf_type == RF_1T1R) {
  1955. if (curtxbw_40mhz) {
  1956. if (rssi_level == 1)
  1957. ratr_bitmap &= 0x000f0000;
  1958. else if (rssi_level == 2)
  1959. ratr_bitmap &= 0x000ff000;
  1960. else
  1961. ratr_bitmap &= 0x000ff015;
  1962. } else {
  1963. if (rssi_level == 1)
  1964. ratr_bitmap &= 0x000f0000;
  1965. else if (rssi_level == 2)
  1966. ratr_bitmap &= 0x000ff000;
  1967. else
  1968. ratr_bitmap &= 0x000ff005;
  1969. }
  1970. } else {
  1971. if (curtxbw_40mhz) {
  1972. if (rssi_level == 1)
  1973. ratr_bitmap &= 0x0f8f0000;
  1974. else if (rssi_level == 2)
  1975. ratr_bitmap &= 0x0ffff000;
  1976. else
  1977. ratr_bitmap &= 0x0ffff015;
  1978. } else {
  1979. if (rssi_level == 1)
  1980. ratr_bitmap &= 0x0f8f0000;
  1981. else if (rssi_level == 2)
  1982. ratr_bitmap &= 0x0ffff000;
  1983. else
  1984. ratr_bitmap &= 0x0ffff005;
  1985. }
  1986. }
  1987. if ((curtxbw_40mhz && b_curshortgi_40mhz) ||
  1988. (!curtxbw_40mhz && b_curshortgi_20mhz)) {
  1989. if (macid == 0)
  1990. b_shortgi = true;
  1991. else if (macid == 1)
  1992. b_shortgi = false;
  1993. }
  1994. break;
  1995. default:
  1996. ratr_index = RATR_INX_WIRELESS_NGB;
  1997. if (rtlphy->rf_type == RF_1T1R)
  1998. ratr_bitmap &= 0x000ff0ff;
  1999. else
  2000. ratr_bitmap &= 0x0f8ff0ff;
  2001. break;
  2002. }
  2003. ratr_index = _rtl92ee_mrate_idx_to_arfr_id(hw, ratr_index);
  2004. sta_entry->ratr_index = ratr_index;
  2005. RT_TRACE(rtlpriv, COMP_RATR, DBG_DMESG,
  2006. "ratr_bitmap :%x\n", ratr_bitmap);
  2007. *(u32 *)&rate_mask = (ratr_bitmap & 0x0fffffff) |
  2008. (ratr_index << 28);
  2009. rate_mask[0] = macid;
  2010. rate_mask[1] = ratr_index | (b_shortgi ? 0x80 : 0x00);
  2011. rate_mask[2] = curtxbw_40mhz;
  2012. rate_mask[3] = (u8)(ratr_bitmap & 0x000000ff);
  2013. rate_mask[4] = (u8)((ratr_bitmap & 0x0000ff00) >> 8);
  2014. rate_mask[5] = (u8)((ratr_bitmap & 0x00ff0000) >> 16);
  2015. rate_mask[6] = (u8)((ratr_bitmap & 0xff000000) >> 24);
  2016. RT_TRACE(rtlpriv, COMP_RATR, DBG_DMESG,
  2017. "Rate_index:%x, ratr_val:%x, %x:%x:%x:%x:%x:%x:%x\n",
  2018. ratr_index, ratr_bitmap, rate_mask[0], rate_mask[1],
  2019. rate_mask[2], rate_mask[3], rate_mask[4],
  2020. rate_mask[5], rate_mask[6]);
  2021. rtl92ee_fill_h2c_cmd(hw, H2C_92E_RA_MASK, 7, rate_mask);
  2022. _rtl92ee_set_bcn_ctrl_reg(hw, BIT(3), 0);
  2023. }
  2024. void rtl92ee_update_hal_rate_tbl(struct ieee80211_hw *hw,
  2025. struct ieee80211_sta *sta, u8 rssi_level)
  2026. {
  2027. struct rtl_priv *rtlpriv = rtl_priv(hw);
  2028. if (rtlpriv->dm.useramask)
  2029. rtl92ee_update_hal_rate_mask(hw, sta, rssi_level);
  2030. }
  2031. void rtl92ee_update_channel_access_setting(struct ieee80211_hw *hw)
  2032. {
  2033. struct rtl_priv *rtlpriv = rtl_priv(hw);
  2034. struct rtl_mac *mac = rtl_mac(rtl_priv(hw));
  2035. u16 sifs_timer;
  2036. rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_SLOT_TIME,
  2037. (u8 *)&mac->slot_time);
  2038. if (!mac->ht_enable)
  2039. sifs_timer = 0x0a0a;
  2040. else
  2041. sifs_timer = 0x0e0e;
  2042. rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_SIFS, (u8 *)&sifs_timer);
  2043. }
  2044. bool rtl92ee_gpio_radio_on_off_checking(struct ieee80211_hw *hw, u8 *valid)
  2045. {
  2046. *valid = 1;
  2047. return true;
  2048. }
  2049. void rtl92ee_set_key(struct ieee80211_hw *hw, u32 key_index,
  2050. u8 *p_macaddr, bool is_group, u8 enc_algo,
  2051. bool is_wepkey, bool clear_all)
  2052. {
  2053. struct rtl_priv *rtlpriv = rtl_priv(hw);
  2054. struct rtl_mac *mac = rtl_mac(rtl_priv(hw));
  2055. struct rtl_efuse *rtlefuse = rtl_efuse(rtl_priv(hw));
  2056. u8 *macaddr = p_macaddr;
  2057. u32 entry_id = 0;
  2058. bool is_pairwise = false;
  2059. static u8 cam_const_addr[4][6] = {
  2060. {0x00, 0x00, 0x00, 0x00, 0x00, 0x00},
  2061. {0x00, 0x00, 0x00, 0x00, 0x00, 0x01},
  2062. {0x00, 0x00, 0x00, 0x00, 0x00, 0x02},
  2063. {0x00, 0x00, 0x00, 0x00, 0x00, 0x03}
  2064. };
  2065. static u8 cam_const_broad[] = {
  2066. 0xff, 0xff, 0xff, 0xff, 0xff, 0xff
  2067. };
  2068. if (clear_all) {
  2069. u8 idx = 0;
  2070. u8 cam_offset = 0;
  2071. u8 clear_number = 5;
  2072. RT_TRACE(rtlpriv, COMP_SEC, DBG_DMESG, "clear_all\n");
  2073. for (idx = 0; idx < clear_number; idx++) {
  2074. rtl_cam_mark_invalid(hw, cam_offset + idx);
  2075. rtl_cam_empty_entry(hw, cam_offset + idx);
  2076. if (idx < 5) {
  2077. memset(rtlpriv->sec.key_buf[idx], 0,
  2078. MAX_KEY_LEN);
  2079. rtlpriv->sec.key_len[idx] = 0;
  2080. }
  2081. }
  2082. } else {
  2083. switch (enc_algo) {
  2084. case WEP40_ENCRYPTION:
  2085. enc_algo = CAM_WEP40;
  2086. break;
  2087. case WEP104_ENCRYPTION:
  2088. enc_algo = CAM_WEP104;
  2089. break;
  2090. case TKIP_ENCRYPTION:
  2091. enc_algo = CAM_TKIP;
  2092. break;
  2093. case AESCCMP_ENCRYPTION:
  2094. enc_algo = CAM_AES;
  2095. break;
  2096. default:
  2097. RT_TRACE(rtlpriv, COMP_ERR, DBG_DMESG,
  2098. "switch case not process\n");
  2099. enc_algo = CAM_TKIP;
  2100. break;
  2101. }
  2102. if (is_wepkey || rtlpriv->sec.use_defaultkey) {
  2103. macaddr = cam_const_addr[key_index];
  2104. entry_id = key_index;
  2105. } else {
  2106. if (is_group) {
  2107. macaddr = cam_const_broad;
  2108. entry_id = key_index;
  2109. } else {
  2110. if (mac->opmode == NL80211_IFTYPE_AP ||
  2111. mac->opmode == NL80211_IFTYPE_MESH_POINT) {
  2112. entry_id = rtl_cam_get_free_entry(hw,
  2113. p_macaddr);
  2114. if (entry_id >= TOTAL_CAM_ENTRY) {
  2115. RT_TRACE(rtlpriv, COMP_SEC,
  2116. DBG_EMERG,
  2117. "Can not find free hw security cam entry\n");
  2118. return;
  2119. }
  2120. } else {
  2121. entry_id = CAM_PAIRWISE_KEY_POSITION;
  2122. }
  2123. key_index = PAIRWISE_KEYIDX;
  2124. is_pairwise = true;
  2125. }
  2126. }
  2127. if (rtlpriv->sec.key_len[key_index] == 0) {
  2128. RT_TRACE(rtlpriv, COMP_SEC, DBG_DMESG,
  2129. "delete one entry, entry_id is %d\n",
  2130. entry_id);
  2131. if (mac->opmode == NL80211_IFTYPE_AP ||
  2132. mac->opmode == NL80211_IFTYPE_MESH_POINT)
  2133. rtl_cam_del_entry(hw, p_macaddr);
  2134. rtl_cam_delete_one_entry(hw, p_macaddr, entry_id);
  2135. } else {
  2136. RT_TRACE(rtlpriv, COMP_SEC, DBG_DMESG,
  2137. "add one entry\n");
  2138. if (is_pairwise) {
  2139. RT_TRACE(rtlpriv, COMP_SEC, DBG_DMESG,
  2140. "set Pairwiase key\n");
  2141. rtl_cam_add_one_entry(hw, macaddr, key_index,
  2142. entry_id, enc_algo,
  2143. CAM_CONFIG_NO_USEDK,
  2144. rtlpriv->sec.key_buf[key_index]);
  2145. } else {
  2146. RT_TRACE(rtlpriv, COMP_SEC, DBG_DMESG,
  2147. "set group key\n");
  2148. if (mac->opmode == NL80211_IFTYPE_ADHOC) {
  2149. rtl_cam_add_one_entry(hw,
  2150. rtlefuse->dev_addr,
  2151. PAIRWISE_KEYIDX,
  2152. CAM_PAIRWISE_KEY_POSITION,
  2153. enc_algo, CAM_CONFIG_NO_USEDK,
  2154. rtlpriv->sec.key_buf[entry_id]);
  2155. }
  2156. rtl_cam_add_one_entry(hw, macaddr, key_index,
  2157. entry_id, enc_algo,
  2158. CAM_CONFIG_NO_USEDK,
  2159. rtlpriv->sec.key_buf[entry_id]);
  2160. }
  2161. }
  2162. }
  2163. }
  2164. void rtl92ee_read_bt_coexist_info_from_hwpg(struct ieee80211_hw *hw,
  2165. bool auto_load_fail, u8 *hwinfo)
  2166. {
  2167. struct rtl_priv *rtlpriv = rtl_priv(hw);
  2168. u8 value;
  2169. if (!auto_load_fail) {
  2170. value = hwinfo[EEPROM_RF_BOARD_OPTION_92E];
  2171. if (((value & 0xe0) >> 5) == 0x1)
  2172. rtlpriv->btcoexist.btc_info.btcoexist = 1;
  2173. else
  2174. rtlpriv->btcoexist.btc_info.btcoexist = 0;
  2175. rtlpriv->btcoexist.btc_info.bt_type = BT_RTL8192E;
  2176. rtlpriv->btcoexist.btc_info.ant_num = ANT_TOTAL_X2;
  2177. } else {
  2178. rtlpriv->btcoexist.btc_info.btcoexist = 1;
  2179. rtlpriv->btcoexist.btc_info.bt_type = BT_RTL8192E;
  2180. rtlpriv->btcoexist.btc_info.ant_num = ANT_TOTAL_X1;
  2181. }
  2182. }
  2183. void rtl92ee_bt_reg_init(struct ieee80211_hw *hw)
  2184. {
  2185. struct rtl_priv *rtlpriv = rtl_priv(hw);
  2186. /* 0:Low, 1:High, 2:From Efuse. */
  2187. rtlpriv->btcoexist.reg_bt_iso = 2;
  2188. /* 0:Idle, 1:None-SCO, 2:SCO, 3:From Counter. */
  2189. rtlpriv->btcoexist.reg_bt_sco = 3;
  2190. /* 0:Disable BT control A-MPDU, 1:Enable BT control A-MPDU. */
  2191. rtlpriv->btcoexist.reg_bt_sco = 0;
  2192. }
  2193. void rtl92ee_bt_hw_init(struct ieee80211_hw *hw)
  2194. {
  2195. struct rtl_priv *rtlpriv = rtl_priv(hw);
  2196. if (rtlpriv->cfg->ops->get_btc_status())
  2197. rtlpriv->btcoexist.btc_ops->btc_init_hw_config(rtlpriv);
  2198. }
  2199. void rtl92ee_suspend(struct ieee80211_hw *hw)
  2200. {
  2201. }
  2202. void rtl92ee_resume(struct ieee80211_hw *hw)
  2203. {
  2204. }
  2205. /* Turn on AAP (RCR:bit 0) for promicuous mode. */
  2206. void rtl92ee_allow_all_destaddr(struct ieee80211_hw *hw,
  2207. bool allow_all_da, bool write_into_reg)
  2208. {
  2209. struct rtl_priv *rtlpriv = rtl_priv(hw);
  2210. struct rtl_pci *rtlpci = rtl_pcidev(rtl_pcipriv(hw));
  2211. if (allow_all_da) /* Set BIT0 */
  2212. rtlpci->receive_config |= RCR_AAP;
  2213. else /* Clear BIT0 */
  2214. rtlpci->receive_config &= ~RCR_AAP;
  2215. if (write_into_reg)
  2216. rtl_write_dword(rtlpriv, REG_RCR, rtlpci->receive_config);
  2217. RT_TRACE(rtlpriv, COMP_TURBO | COMP_INIT, DBG_LOUD,
  2218. "receive_config=0x%08X, write_into_reg=%d\n",
  2219. rtlpci->receive_config, write_into_reg);
  2220. }